springboot整合dubbo
2017-06-13 14:53
465 查看
基于前文整合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文件
三、最后一步,在springboot启动入口处引入dubbo-server.xml文件
至此已经完成dubbo集成。本文只列出了dubbo服务提供方的配置方法,至于提供方读者感兴趣的话可自行验证。provider和consumer同时运行可能需要修改springboot启动的默认端口号,修改默认端口号的方法:在application.properties文件中加入server.port=8084 即可。需要源码可以访问如下地址
源代码地址:https://git.oschina.net/wangyoubinchuan/springboot-mybatis-demo.git
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 即可。需要源码可以访问如下地址
源代码地址:https://git.oschina.net/wangyoubinchuan/springboot-mybatis-demo.git
相关文章推荐
- springboot整合dubbo-start
- Spring Boot整合Dubbo使用及开发笔记
- Spring boot 整合Dubbo
- springboot dubbo的整合以及与springcloud fein的对比
- Spring Boot整合Dubbo框架demo
- SpringBoot整合Dubbox(无XML配置)
- Spring Boot Dubbo 整合和入门理解
- springboot 整合dubbo最佳实践 (使用redis作为注册中心)
- springboot整合dubbo
- 用springBoot与dubbo、 zookeeper、redis整合做了一个弹幕网站
- Springboot整合dubbo构建maven多模块项目(四) - 集成mybatis
- 通过Spring-boot整合dubbo框架
- spring-boot整合dubbo:Spring-boot-dubbo-starter
- SpringBoot整合Dubbo2.5.10,使用官方最新spring-boot-starter
- Spring-boot:5分钟整合Dubbo构建分布式服务
- SpringBoot学习笔记(7) SpringBoot整合Dubbo(使用yml配置)
- 使用spring boot搭建与dubbo整合项目
- Springboot 整合 Dubbo/ZooKeeper 详解 SOA 案例
- Springboot 整合 Dubbo/ZooKeeper 实现 SOA 案例解析
- Spring Boot对dubbo的整合