springboot分布式整合dubbo的方式
Dubbo是Alibaba開源的分布式服務框架,它最大的特點是按照分層的方式來架構,使用這種方式可以使各個層之間解耦合(或者最大限度地松耦合)。從服務模型的角度來看,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中進行依賴注入和調用
@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 );
}
}
到此這篇關于springboot(分布式)整合dubbo的文章就介紹到這了,更多相關springboot整合dubbo內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
- 詳解SpringBoot開發(fā)案例之整合Dubbo分布式服務
- Springboot-dubbo-fescar 阿里分布式事務的實現(xiàn)方法
- Spring Boot Dubbo 構建分布式服務的方法
- 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搭建一個簡單的分布式詳情
相關文章
SpringBoot實現(xiàn)RBAC權限校驗模型的示例
本文主要介紹了SpringBoot實現(xiàn)RBAC權限校驗模型的示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2025-04-04
關于重寫equals()方法和hashCode()方法及其簡單的應用
這篇文章主要介紹了關于重寫equals()方法和hashCode()方法及其簡單的應用,網上的知識有些可能是錯誤的,關于?equals()?方法的理解,大家討論不一樣,需要的朋友可以參考下2023-04-04
SpringBoot整合Mybatis-plus的具體過程使用
這篇文章主要介紹了SpringBoot?整合mybatis+mybatis-plus的步驟,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-06-06
Springboot與vue實現(xiàn)數(shù)據(jù)導出方法具體介紹
這篇文章主要介紹了Springboot與vue實現(xiàn)數(shù)據(jù)導出方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧2023-02-02

