springboot分布式整合dubbo的方式
Dubbo是Alibaba開源的分布式服務框架,它最大的特點是按照分層的方式來架構(gòu),使用這種方式可以使各個層之間解耦合(或者最大限度地松耦合)。從服務模型的角度來看,Dubbo采用的是一種非常簡單的模型,要么是提供方提供服務,要么是消費方消費服務,所以基于這一點可以抽象出服務提供方(Provider)和服務消費方(Consumer)兩個角色。
1.服務提供者配置
//需要額外引入的jar包 提供者 <dependency> <groupId>com.alibaba.boot</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>0.2.0</version> </dependency> <dependency> <groupId>com.github.sgroschupf</groupId> <artifactId>zkclient</artifactId> <version>0.1</version> </dependency>
spring配置方式
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="http://code.alibabatech.com/schema/dubbo" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd"> <dubbo:application name="user-service-provider"></dubbo:application> <!-- 指定注冊中心的地址,將來服務提供者要向注冊中心進行注冊--> <dubbo:registry address="zookeeper://192.168.192.3:2181"></dubbo:registry> <!-- 指定將來服務消費者消費我的時候使用的rpc協(xié)議 --> <dubbo:protocol name="dubbo" port="11123"></dubbo:protocol> <!-- 服務發(fā)布 --> <bean id="userService" class="com.oracle.shop.user.service.impl.UserServiceImpl"></bean> <dubbo:service interface="com.oracle.shop.user.service.UserService" ref="userService"></dubbo:service> </beans>
springboot配置方式
#dubbo的配置 #服務名 dubbo.application.name=user-provider #注冊中心地址 dubbo.registry.address=zookeeper://192.168.192.3:2181 #使用的協(xié)議以及端口號 dubbo.protocol.name=dubbo dubbo.protocol.port=11111
發(fā)布服務的方式
在相應的實現(xiàn)類上添加注解
import com.alibaba.dubbo.config.annotation.Service; import com.oracle.shopping.user.mapper.MenuMapper; import com.oracle.shopping.user.po.Menu; import com.oracle.shopping.user.service.MenuService; import javax.annotation.Resource; @Service //dubbo的注解表示發(fā)布該類 @org.springframework.stereotype.Service//spring的注解表示會在啟動時實例化該類 public class MenuServiceImpl implements MenuService { @Resource private MenuMapper menuMapper; @Override public int deleteByPrimaryKey(String id) { return menuMapper.deleteByPrimaryKey(id); } @Override public int insert(Menu record) { return menuMapper.insert(record); } @Override public int insertSelective(Menu record) { return menuMapper.insertSelective(record); } @Override public Menu selectByPrimaryKey(String id) { return menuMapper.selectByPrimaryKey(id); } @Override public int updateByPrimaryKeySelective(Menu record) { return menuMapper.updateByPrimaryKeySelective(record); } @Override public int updateByPrimaryKey(Menu record) { return menuMapper.updateByPrimaryKey(record); } }
啟動類中添加dubbo的掃包器,設置掃描路徑
@SpringBootApplication @MapperScan("com.oracle.shopping.user.mapper") @EnableTransactionManagement @DubboComponentScan("com.oracle.shopping.user.service.impl") public class UserProviderApp { public static void main(String[] args) { SpringApplication.run(UserProviderApp.class, args); } }
2.服務消費者訂閱
<dependency> <groupId>com.alibaba.boot</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>0.2.0</version> </dependency> <dependency> <groupId>com.github.sgroschupf</groupId> <artifactId>zkclient</artifactId> <version>0.1</version> </dependency>
spring配置方式
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="http://code.alibabatech.com/schema/dubbo" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd"> <dubbo:application name="user-web-consumer"></dubbo:application> <!-- 指定注冊中心的地址,將來服務提供者要向注冊中心進行注冊--> <dubbo:registry address="zookeeper://192.168.192.3:2181"></dubbo:registry> <!-- 訂閱具體服務,讓dubbo幫咱們生成動態(tài)代理客戶端對象--> <dubbo:reference interface="com.oracle.shop.user.service.UserService" id="userService"></dubbo:reference> <dubbo:reference interface="com.oracle.shop.order.service.OrderService" id="orderService"></dubbo:reference> </beans>
在controller中進行依賴注入和調(diào)用
@Controller @RequestMapping("/user") public class UserController { //通過動態(tài)代理的方式生成的動態(tài)代理類 @Autowired(required = false) private UserService userService; //不進行檢查,防止報錯無法運行 @Autowired(required = false) private OrderService orderService; @RequestMapping("/a") public @ResponseBody User detail(){ return userService.findUserById(1); } @RequestMapping("/b") public @ResponseBody Orders details(){ return orderService.findUserById(1); } }
springboot配置方式
#指定自己的名稱 dubbo.application.name=user-consumer #指定注冊中心的地址 dubbo.registry.address=zookeeper://192.168.192.3:2181
?在controller當中使用注解聲明要使用的服務(實現(xiàn)類)
@RestController @RequestMapping("/user") public class UserController { //表示要使用的服務 @Reference(interfaceName = "com.oracle.shopping.user.service.UserService") private UserService userService; @Autowired private RedisTemplate redisTemplate; @RequestMapping("/detail") public User detail(String id){ return userService.selectByPrimaryKey(id); } }
啟動類中設置dobbo注解的掃描路徑
@SpringBootApplication @DubboComponentScan("com.oracle.shopping.user.controller") public class UserConsumerApp { public static void main(String[] args) { SpringApplication.run(UserConsumerApp.class ); } }
到此這篇關(guān)于springboot(分布式)整合dubbo的文章就介紹到這了,更多相關(guān)springboot整合dubbo內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 詳解SpringBoot開發(fā)案例之整合Dubbo分布式服務
- Springboot-dubbo-fescar 阿里分布式事務的實現(xiàn)方法
- Spring Boot Dubbo 構(gòu)建分布式服務的方法
- SpringBoot+Dubbo+Seata分布式事務實戰(zhàn)詳解
- 詳解SpringBoot基于Dubbo和Seata的分布式事務解決方案
- SpringBoot中dubbo+zookeeper實現(xiàn)分布式開發(fā)的應用詳解
- SpringBoot+Dubbo+Zookeeper實現(xiàn)簡單分布式開發(fā)的應用詳解
- springBoot+dubbo+zookeeper實現(xiàn)分布式開發(fā)應用的項目實踐
- Spring與Dubbo搭建一個簡單的分布式詳情
相關(guān)文章
一篇文章帶你搞定SpringBoot中的熱部署devtools方法
這篇文章主要介紹了一篇文章帶你搞定SpringBoot中的熱部署devtools方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-09-09springboot使用redisTemplate操作lua腳本
本文主要介紹了springboot使用redisTemplate操作lua腳本,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-08-08Spring?Boot?整合JPA?數(shù)據(jù)模型關(guān)聯(lián)使用操作(一對一、一對多、多對多)
這篇文章主要介紹了Spring?Boot?整合JPA?數(shù)據(jù)模型關(guān)聯(lián)操作(一對一、一對多、多對多),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-07-07