Dubbo集成步骤
dubbo协议实现与webservice一样的效果,用于服务调用之间的接口。dubbo可在中间实现真正意义上的中间调用管理,是一个中间管理系统。
demo:http://www.devnote.cn/download/182
同步服务端集成
同步服务端统一试用dubbo服务端集成到业务系统。目前的场景试用的是dubbo协议。
1、加入dubbo jar包(附件2.4.10-jar.zip)
2、在spring配置文件中加入dubbo provider配置
<?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"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://code.alibabatech.com/schema/dubbo
http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
<!-- 省略无关配置 -->
<!-- 提供方应用信息,用于计算依赖关系 -->
<dubbo:application name="dubbo-app" />
<!-- 使用zookeeper注册中心暴露服务地址 -->
<dubbo:registry address="zookeeper://IP:PORT"
check="false" />
<!-- 用dubbo协议在20880端口暴露服务 -->
<dubbo:protocol name="dubbo" port="20880" />
<!-- 声明需要暴露的服务接口 -->
<dubbo:service interface="com.dubbo.provider.service.DubboService"
ref="dubboService" protocol="dubbo" retries="0" timeout="100000" />
<!-- 和本地bean一样实现服务 -->
<bean id="dubboService" class="com.dubbo.provider.service.impl.DubboServiceImpl" />
</beans>
<dubbo:application/> :应用配置,用于配置当前应用信息,不管该应用是提供者还是消费者。
<dubbo:service/> :服务配置,用于暴露一个服务,定义服务的元信息,一个服务可以用多个协议暴露,一个服务也可以注 册到多个注册中心。
<dubbo:protocol/> :协议配置,用于配置提供服务的协议信息,协议由提供方指定,消费方被动接受。
<dubbo:registry/> :注册中心配置,用于配置连接注册中心相关信息。
3、把相应的外部接口和所用到的bean(bean或bean的基类要实例化)打成一个jar包
同步客户端集成
1、客户端也许加入相应的dubbojar(2.4.10-jar.zip)
2、加入dubbo client配置
<?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="dubbo-custom-app" />
<!-- 使用zookeeper注册中心暴露发现服务地址 -->
<dubbo:registry address="zookeeper://IP:PORT"
check="false" />
<dubbo:monitor protocol="registry" />
<dubbo:protocol name="dubbo" port="20880" />
<!-- 生成远程服务代理,可以和本地bean一样使用dubboService -->
<dubbo:reference id="dubboService"
interface="com.dubbo.provider.service.DubboService" protocol="dubbo"
retries="0" timeout="10000" check="false">
<!--<dubbo:method name="insertOrUpdateCustomer" async="true" /> -->
</dubbo:reference>
</beans>
<dubbo:reference/> 引用配置,用于创建一个远程服务代理,一个引用可以指向多个注册中心。
3、引入服务方提供的接口和bean打的jar包
服务方实现读写分离
若服务方要实现读写分离,可参考如下方案:
服务端的配置
<!-- 声明需要暴露的服务接口 -->
<!--读服务配置 -->
<dubbo:service group="editDevnoteByClient"
interface="com.devnote.webService.server.TestService" ref="TestService"
protocol="dubbo" retries="0" timeout="100000" /> <!--写服务配置 -->
<dubbo:service group="queryDevnoteByClient"
interface="com.devnote.webService.server.TestService" ref="TestService"
protocol="dubbo" retries="0" timeout="100000" /> <!-- 和本地bean一样实现服务 -->
<bean id="TestService" class="com.devnote.webService.server.TestServiceImpl" />
客户端的配置
<!-- 生成远程服务代理,可以和本地bean一样使用dubboService -->
<!--读服务配置 -->
<dubbo:reference id="testServiceEdit" group="editDevNoteByClient"
listener="" interface="com.devnote.webService.server.TestService"
protocol="dubbo" retries="0" timeout="10000" check="false">
</dubbo:reference> <!--写服务配置 -->
<dubbo:reference id="testServiceReader" group="queryDevNoteByClient"
interface="com.devnote.webService.server.TestService" protocol="dubbo"
retries="0" timeout="10000" check="false">
</dubbo:reference>
注意点:
- 服务端与客户端配置的【zookeeper注册中心暴露服务地址】是由dubbo服务方提供
<dubbo:registry address="zookeeper://IP:PORT" check="false"/>
- 用dubbo协议在20880端口暴露服务
name:应用方自己暴露在dubbo方的服务名称
port:类似于自己的tomcat端口,当你的系统有多个服务并分别有应用dubbo时,每个服务都要设置不一样 的端口,否则会系统会报端口冲突错误<dubbo:protocol name="dubbo" port="20880" />
- 服务端与客户端通过接口来识别调用
<dubbo:service interface="com.dubbo.provider.service.DubboService"
ref="dubboService" protocol="dubbo" retries="0" timeout="100000" /> - 如果服务方要实现读写分离则是通过group和接口两个来识别调用
<dubbo:service group="editDubboByClient"
interface="com.devnote.webService.server.DubboService" ref="TestService"protocol="dubbo" retries="0" timeout="100000" />
最新文章
- 脚本工具(获取某个文件夹下的所有图片属性批量生成css样式)
- Python-socket网络编程
- Access denied for user &#39;Administrator&#39;@&#39;localhost&#39; (using password: YES)
- Application对象、Session对象、Cookie对象、Server对象初步认识
- C#之类的继承、抽象类和虚方法
- C#基本概念列举说明
- joj 2453 candy 网络流建图的题
- verview of Spring Framework--转
- Html5/Css3 向下兼容placeholder
- Docker学习总结之Run命令介绍
- C# Web.config 配置handlers 和 httpHandlers
- 考了3年,工作四年,零基础在职终于拿到CFA证书
- CCNA笔记(1)
- jieba 库的使用和好玩的词云
- c++错误
- shell脚本,如果文件中的第一列有相同的,就把相同的那些行的其他字段相加
- Maven+SSM框架(Spring+SpringMVC+MyBatis)(二)
- Catfish CMS漏洞集合
- MyEclipse6.5的反编译插件的安装
- Oracle_高级功能(2) 索引