springboot整合dubbo

基于前文整合mybatis的基础上本文在新加入dubbo。我们常常使用 Springboot 暴露 HTTP 服务,并走 JSON 模式。但慢慢量大了,需要一种 SOA 的治理方案。而Dubbo 不单单只是高性能的 RPC 调用框架,更是 SOA 服务治理的一种方案。其核心:
1. 远程通信,向本地调用一样调用远程方法。
2. 集群容错
3. 服务自动发现和注册,可平滑添加或者删除服务提供者。
下面讲解如何集成dubbo。

一、pom.xml文件需要引入dubbo及zk相关的jar包。由于dubbo自带的spring版本以及zk的sf4j版本和springboot的会有冲突,所以在引入这duubo和zk的时候需要将相关的冲突项排除。

  <!-- 集成dubbo -->
		<dependency>
			<groupId>com.alibaba</groupId>
			<artifactId>dubbo</artifactId>
			<version>2.5.3</version>
			<exclusions>
				<exclusion>
					<groupId>org.springframework</groupId>
					<artifactId>spring</artifactId>
				</exclusion>
			</exclusions>
		</dependency>
		<dependency>
			<groupId>org.apache.zookeeper</groupId>
			<artifactId>zookeeper</artifactId>
			<version>3.4.6</version>
			<exclusions>
				<exclusion>
					<groupId>org.slf4j</groupId>
					<artifactId>slf4j-log4j12</artifactId>
				</exclusion>
				<exclusion>
					<groupId>log4j</groupId>
					<artifactId>log4j</artifactId>
				</exclusion>
			</exclusions>
		</dependency>
		<dependency>
			<groupId>com.github.sgroschupf</groupId>
			<artifactId>zkclient</artifactId>
			<version>0.1</version>
		</dependency>

二、dubbo-server.xml文件
<?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:jee="http://www.springframework.org/schema/jee"
    xmlns:tx="http://www.springframework.org/schema/tx"
    xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
    xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
    http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.1.xsd
    http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-3.1.xsd
    http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd
    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.1.xsd"
    default-lazy-init="false" >
   <!-- 提供方应用名称信息,这个相当于起一个名字,我们dubbo管理页面比较清晰是哪个应用暴露出来的 -->
   <dubbo:application name="dubbo-provider-user"></dubbo:application>

   <!-- 使用zookeeper注册中心暴露服务地址 -->  
   <dubbo:registry address="zookeeper://127.0.0.1:2181" check="false" subscribe="false" protocol="zookeeper"></dubbo:registry>
   <!-- 用dubbo协议在20880端口暴露服务 -->
    <dubbo:protocol name="dubbo" port="20880" />
  <!-- 要暴露的服务接口 -->  
  <dubbo:service interface="org.zt.ccty.springboot_mybatis_demo.service.UserService" ref="userServiceImpl"/>  

</beans>
三、最后一步,在springboot启动入口处引入dubbo-server.xml文件
@EnableAutoConfiguration
@SpringBootApplication
@ComponentScan
@MapperScan("org.zt.ccty.springboot_mybatis_demo.dao")
@ImportResource("classpath:/beans/*.xml")
public class Application {
	private static Logger log = LoggerFactory.getLogger(Application.class);

    @Value("${spring.datasource.type}")  
    private Class<? extends DataSource> dataSourceType;  
  
    @Value("${datasource.readSize}")  
    private String dataSourceSize;  
    @Resource(name = "writeDataSource")  
    private DataSource dataSource;  
    @Resource(name = "readDataSources")  
    private List<DataSource> readDataSources; 
    

至此已经完成dubbo集成。本文只列出了dubbo服务提供方的配置方法,至于提供方读者感兴趣的话可自行验证。provider和consumer同时运行可能需要修改springboot启动的默认端口号,修改默认端口号的方法:在application.properties文件中加入server.port=8084 即可。需要源码可以访问如下地址




  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值