今天就跟大家聊聊有關(guān)dubbo與zookeeper怎么在springboot中使用,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
按需策劃設(shè)計可以根據(jù)自己的需求進行定制,做網(wǎng)站、成都網(wǎng)站設(shè)計構(gòu)思過程中功能建設(shè)理應(yīng)排到主要部位公司做網(wǎng)站、成都網(wǎng)站設(shè)計的運用實際效果公司網(wǎng)站制作網(wǎng)站建立與制做的實際意義創(chuàng)建服務(wù)接口模塊
接口工程只提供接口,不提供實現(xiàn),在后面的提供者和消費者中使用
在使用接口的模塊中只需要寫具體實現(xiàn)類,避免了在每個模塊中重復編寫接口
在接口中引入依賴包
<dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency>
創(chuàng)建一個實體類,一定要實現(xiàn)Serializable接口,否則dubbo協(xié)議之間無法傳輸
@Data @AllArgsConstructor public class User implements Serializable { private String name; }
創(chuàng)建接口
public interface UserService { List<User> getAll(); List<User> getAll2(); }
創(chuàng)建服務(wù)提供者
引入依賴
<!--引入創(chuàng)建的接口服務(wù)--> <dependency> <groupId>com.yls</groupId> <artifactId>common-api</artifactId> <version>1.0-SNAPSHOT</version> </dependency> <!--由于服務(wù)提供者不是web項目 ,只需引入spring-boot-starter,不用引入spring-boot-starter-web--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <!--dubbo--> <dependency> <groupId>com.alibaba.boot</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>0.2.0</version> </dependency>
修改配置文件
#服務(wù)名稱 dubbo.application.name=provider1 #注冊中心地址 dubbo.registry.address=39.97.234.52:2181,39.97.234.52:2182,39.97.234.52:2183 #注冊中心類型 dubbo.registry.protocol=zookeeper #版本號 dubbo.application.version=3 # Dubbo Protocol #協(xié)議名稱 dubbo.protocol.name=dubbo #服務(wù)暴露端口 dubbo.protocol.port=20880
實現(xiàn)服務(wù)接口
//暴露服務(wù) //這里的@Service是Dubbo提供的,不是spring中的 //version必填 @Service(version = "${dubbo.application.version}") @Component public class UserImpl implements UserService { @Override public List<User> getAll() { User user1 = new User("張三"); User user2 = new User("lisi"); List<User> list = Arrays.asList(user1, user2); return list; } }
啟動服務(wù)
//@EnableDubbo等價于在配置文件中配置dubbo.scan.base-packages //掃描實現(xiàn)類所在的包,注冊Bean @EnableDubbo @SpringBootApplication public class ProviderApplication { public static void main(String[] args) { SpringApplication.run(ProviderApplication.class,args); } }
創(chuàng)建消費者
引入依賴
<!--消費者是web項目--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!--dubbo--> <dependency> <groupId>com.alibaba.boot</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>0.2.0</version> </dependency> <!--引入創(chuàng)建的接口服務(wù)--> <dependency> <groupId>com.yls</groupId> <artifactId>common-api</artifactId> <version>1.0-SNAPSHOT</version> </dependency>
修改配置文件
#注冊中心 dubbo.registry.address=39.97.234.52:2181,39.97.234.52:2182,39.97.234.52:2183 dubbo.registry.protocol=zookeeper #dubbo應(yīng)用名稱 dubbo.application.name=consumer1
實現(xiàn)消費接口
//服務(wù)消費者的Service是spring的 @Service public class OrderImpl implements OrderService { //使用dubbo提供的@Reference訪問遠程服務(wù) //version對應(yīng)服務(wù)提供者的version @Reference(version = "3") private UserService userService; @Override public List<User> init() { List<User> list = userService.getAll(); list.forEach(item -> System.out.println(item.getName())); return list; } }
創(chuàng)建controller
@Controller public class OrderController { @Autowired private OrderService orderService; @ResponseBody @RequestMapping("/init") public List<User> init() { return orderService.init(); } }
啟動服務(wù)消費者
@EnableDubbo @SpringBootApplication public class ConsumerApplication { public static void main(String[] args) { SpringApplication.run(ConsumerApplication.class, args); } }
dubbo相關(guān)補充
dubbo使用本地緩存方式,如果注冊中心全部宕機,dubbo也能正常工作,就算沒有注冊中心,dubbo也能通過dubbo直連通信
//使用dubbo提供的@Reference訪問遠程服務(wù) //version對應(yīng)服務(wù)提供者的version //url:如果沒有注冊中心,可以通過url配置服務(wù)提供者的dubbo協(xié)議端口,進行dubbo直連 @Reference(version = "3",url ="127.0.0.1:20880" ) private UserService userService;
看完上述內(nèi)容,你們對dubbo與zookeeper怎么在springboot中使用有進一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝大家的支持。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站aaarwkj.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
本文名稱:dubbo與zookeeper怎么在springboot中使用-創(chuàng)新互聯(lián)
轉(zhuǎn)載來源:http://aaarwkj.com/article2/ishoc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供Google、網(wǎng)站收錄、靜態(tài)網(wǎng)站、ChatGPT、網(wǎng)頁設(shè)計公司、云服務(wù)器
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容