springboot使用dubbo和zookeeper代碼實(shí)例
這篇文章主要介紹了springboot使用dubbo和zookeeper代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
創(chuàng)建服務(wù)接口模塊
接口工程只提供接口,不提供實(shí)現(xiàn),在后面的提供者和消費(fèi)者中使用
在使用接口的模塊中只需要寫具體實(shí)現(xiàn)類,避免了在每個(gè)模塊中重復(fù)編寫接口
在接口中引入依賴包
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
創(chuàng)建一個(gè)實(shí)體類,一定要實(shí)現(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項(xiàng)目
,只需引入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 #版本號(hào) dubbo.application.version=3 # Dubbo Protocol #協(xié)議名稱 dubbo.protocol.name=dubbo #服務(wù)暴露端口 dubbo.protocol.port=20880
實(shí)現(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;
}
}
啟動(dòng)服務(wù)
//@EnableDubbo等價(jià)于在配置文件中配置dubbo.scan.base-packages
//掃描實(shí)現(xiàn)類所在的包,注冊Bean
@EnableDubbo
@SpringBootApplication
public class ProviderApplication {
public static void main(String[] args) {
SpringApplication.run(ProviderApplication.class,args);
}
}
創(chuàng)建消費(fèi)者
引入依賴
<!--消費(fèi)者是web項(xiàng)目-->
<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
實(shí)現(xiàn)消費(fèi)接口
//服務(wù)消費(fèi)者的Service是spring的
@Service
public class OrderImpl implements OrderService {
//使用dubbo提供的@Reference訪問遠(yuǎn)程服務(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();
}
}
啟動(dòng)服務(wù)消費(fèi)者
@EnableDubbo
@SpringBootApplication
public class ConsumerApplication {
public static void main(String[] args) {
SpringApplication.run(ConsumerApplication.class, args);
}
}
dubbo相關(guān)補(bǔ)充
dubbo使用本地緩存方式,如果注冊中心全部宕機(jī),dubbo也能正常工作,就算沒有注冊中心,dubbo也能通過dubbo直連通信
//使用dubbo提供的@Reference訪問遠(yuǎn)程服務(wù) //version對應(yīng)服務(wù)提供者的version //url:如果沒有注冊中心,可以通過url配置服務(wù)提供者的dubbo協(xié)議端口,進(jìn)行dubbo直連 @Reference(version = "3",url ="127.0.0.1:20880" ) private UserService userService;
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
如何使用Gradle實(shí)現(xiàn)類似Maven的profiles功能
這篇文章主要介紹了如何使用Gradle實(shí)現(xiàn)類似Maven的profiles功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2024-06-06
HttpServletResponse亂碼問題_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了HttpServletResponse亂碼問題,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07
Java concurrency集合之ConcurrentSkipListSet_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要為大家詳細(xì)介紹了Java concurrency集合之ConcurrentSkipListSet的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06
SpringBoot使用RestTemplate發(fā)送http請求的實(shí)操演示
RestTemplate是Spring 框架提供的 ,可用于在應(yīng)用中調(diào)用 rest 服務(wù),它簡化了與 http 服務(wù)的通信方式,統(tǒng)一了 RESTful 的標(biāo)準(zhǔn),封裝了 http 鏈接,本文給大家介紹了SpringBoot使用RestTemplate發(fā)送http請求的實(shí)操演示,需要的朋友可以參考下2024-11-11
功能強(qiáng)大的TraceId?搭配?ELK使用詳解
這篇文章主要為大家介紹了功能強(qiáng)大的TraceId?搭配?ELK使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09
springboot通過spel結(jié)合aop實(shí)現(xiàn)動(dòng)態(tài)傳參的案例
SpEl 是Spring框架中的一個(gè)利器,Spring通過SpEl能在運(yùn)行時(shí)構(gòu)建復(fù)雜表達(dá)式、存取對象屬性、對象方法調(diào)用等,今天通過本文給大家介紹springboot?spel結(jié)合aop實(shí)現(xiàn)動(dòng)態(tài)傳參,需要的朋友可以參考下2022-07-07
詳解Java對象序列化為什么要使用SerialversionUID
這篇文章主要介紹了詳解Java對象序列化為什么要使用SerialversionUID,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
Java excel數(shù)據(jù)導(dǎo)入mysql的實(shí)現(xiàn)示例詳解
今天教大家如何使用Java將excel數(shù)據(jù)導(dǎo)入MySQL,文中有非常詳細(xì)的代碼示例,對正在學(xué)習(xí)java的小伙伴呢很有幫助,需要的朋友可以參考下2022-08-08

