dubbo简单配置与使用

dubbo简介

随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已没法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进。html

这里写图片描述

单一应用架构
当网站流量很小时,只需一个应用,将全部功能都部署在一块儿,以减小部署节点和成本。
此时,用于简化增删改查工做量的 数据访问框架(ORM) 是关键。前端

垂直应用架构
当访问量逐渐增大,单一应用增长机器带来的加速度愈来愈小,将应用拆成互不相干的几个应用,以提高效率。
此时,用于加速前端页面开发的 Web框架(MVC) 是关键。git

分布式服务架构
当垂直应用愈来愈多,应用之间交互不可避免,将核心业务抽取出来,做为独立的服务,逐渐造成稳定的服务中心,使前端应用能更快速的响应多变的市场需求。
此时,用于提升业务复用及整合的 分布式服务框架(RPC) 是关键。github

流动计算架构
当服务愈来愈多,容量的评估,小服务资源的浪费等问题逐渐显现,此时需增长一个调度中心基于访问压力实时管理集群容量,提升集群利用率。
此时,用于提升机器利用率的 资源调度和治理中心(SOA) 是关键。算法

dubbo架构构成

这里写图片描述

1、Provider:暴露服务的服务提供方。 Consumer: 调用远程服务的服务消费方。
2、Registry:服务注册与发现的注册中心。 Monitor: 统计服务的调用次调和调用时间的监控中心。
3、Container: 服务运行容器。

调用关系说明:
一、服务容器负责启动,加载,运行服务提供者。
二、服务提供者在启动时,向注册中心注册本身提供的服务。
三、服务消费者在启动时,向注册中心订阅本身所需的服务。
四、注册中心返回服务提供者地址列表给消费者,若是有变动,注册中心将基于长链接推送变动数据给消费者。
五、服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,若是调用失败,再选另外一台调用。
六、服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。数据库

dubbo特性

(1) 连通性:

注册中心负责服务地址的注册与查找,至关于目录服务,服务提供者和消费者只在启动时与注册中心交互,注册中心不转发请求,压力较小监控中心负责统计各服务调用次数,调用时间等,统计先在内存汇总后每分钟一次发送到监控中心服务器,并以报表展现服务提供者向注册中心注册其提供的服务,并汇报调用时间到监控中心,此时间不包含网络开销服务消费者向注册中心获取服务提供者地址列表,并根据负载算法直接调用提供者,同时汇报调用时间到监控中心,此时间包含网络开销注册中心,服务提供者,服务消费者三者之间均为长链接,监控中心除外注册中心经过长链接感知服务提供者的存在,服务提供者宕机,注册中心将当即推送事件通知消费者注册中心和监控中心所有宕机,不影响已运行的提供者和消费者,消费者在本地缓存了提供者列表 
注册中心和监控中心都是可选的,服务消费者能够直连服务提供者

(2) 健状性:

监控中心宕掉不影响使用,只是丢失部分采样数据数据库宕掉后,注册中心仍能经过缓存提供服务列表查询,但不能注册新服务注册中心对等集群,任意一台宕掉后,将自动切换到另外一台注册中心所有宕掉后,服务提供者和服务消费者仍能经过本地缓存通信服务提供者无状态,任意一台宕掉后,不影响使用服务提供者所有宕掉后,服务消费者应用将没法使用,并没有限次重连等待服务提供者恢复

(3) 伸缩性:

注册中心为对等集群,可动态增长机器部署实例,全部客户端将自动发现新的注册中心 
服务提供者无状态,可动态增长机器部署实例,注册中心将推送新的服务提供者信息给消费者

(4) 升级性:

当服务集群规模进一步扩大,带动IT治理结构进一步升级,须要实现动态部署,进行流动计算,现有分布式服务架构不会带来阻力:

dubbo的调用方式

基于NIO的非阻塞实现并行调用,客户端不须要启动多线程便可完成并行调用多个远程服务,相对多线程开销较小。apache

这里写图片描述

本地调用,使用了Injvm协议,是一个伪协议,它不开启端口,不发起远程调用,只在JVM内直接关联,但执行Dubbo的Filter链。注意:服务暴露与服务引用都须要声明injvm=“true”编程

<dubbo:reference injvm="true" .../>
<dubbo:service injvm="true" .../>

支持的注册中心

Multicast注册中心
Zookeeper注册中心
Redis注册中心
Simple注册中心

支持的远程通讯协议

Mina
Netty
Grizzly

支持的远程调用协议

Dubbo协议
Hessian协议
HTTP协议
RMI协议
WebService协议
Thrift协议
Memcached协议
Redis协议

集群容灾

在集群调用失败时,Dubbo提供了多种容错方案,缺省为failover重试。缓存

Failover Cluster 
失败自动切换,当出现失败,重试其它服务器。(缺省) 
一般用于读操做,但重试会带来更长延迟。 
可经过retries=“2”来设置重试次数(不含第一次)。

Failfast Cluster 
快速失败,只发起一次调用,失败当即报错。 
一般用于非幂等性的写操做,好比新增记录。

Failsafe Cluster 
失败安全,出现异常时,直接忽略。 
一般用于写入审计日志等操做。

Failback Cluster 
失败自动恢复,后台记录失败请求,定时重发。 
一般用于消息通知操做。

Forking Cluster 
并行调用多个服务器,只要一个成功即返回。 
一般用于实时性要求较高的读操做,但须要浪费更多服务资源。 
可经过forks=“2”来设置最大并行数。

Broadcast Cluster 
广播调用全部提供者,逐个调用,任意一台报错则报错。(2.1.0开始支持) 
一般用于通知全部提供者更新缓存或日志等本地资源信息。

集群负载均衡

Random LoadBalance随机,按权重设置随机几率。
在一个截面上碰撞的几率高,但调用量越大分布越均匀,并且按几率使用权重后也比较均匀,有利于动态调整提供者权重。tomcat

RoundRobin LoadBalance 轮循,按公约后的权重设置轮循比率。 
存在慢的提供者累积请求问题,好比:第二台机器很慢,但没挂,当请求调到第二台时就卡在那,长此以往,全部请求都卡在调到第二台上。

LeastActive LoadBalance 最少活跃调用数,相同活跃数的随机,活跃数指调用先后计数差。 
使慢的提供者收到更少请求,由于越慢的提供者的调用先后计数差会越大。

ConsistentHash LoadBalance 一致性Hash,相同参数的请求老是发到同一提供者。 
当某一台提供者挂时,本来发往该提供者的请求,基于虚拟节点,平摊到其它提供者,不会引发剧烈变更。

配置:
<dubbo:service interface="..." loadbalance="roundrobin" />

dubbo-demo

准备工做

下载安装zookeeper

下载安装tomcat

demo

一、新建接口

二、服务端配置

三、调用端配置

demo源码地址

https://gitee.com/xuliugen/dubbodemo.git

dubbo配置文件详解

经常使用配置明细

http://www.cnblogs.com/zhangyaxiao/p/8183443.html

超时设置

上图中以timeout为例,显示了配置的查找顺序,其它retries, loadbalance, actives也相似。
方法级优先,接口级次之,全局配置再次之。
若是级别同样,则消费方优先,提供方次之。

其中,服务提供方配置,经过URL经由注册中心传递给消费方。
建议由服务提供方设置超时,由于一个方法须要执行多长时间,服务提供方更清楚,若是一个消费方同时引用多个服务,就不须要关心每一个服务的超时设置。
理论上ReferenceConfig的非服务标识配置,在ConsumerConfig,ServiceConfig, ProviderConfig都可以缺省配置。

启动时检查

Dubbo缺省会在启动时检查依赖的服务是否可用,不可用时会抛出异常,阻止Spring初始化完成,以便上线时,能及早发现问题,默认check=true。

若是你的Spring容器是懒加载的,或者经过API编程延迟引用服务,请关闭check,不然服务临时不可用时,会抛出异常,拿到null引用,若是check=false,老是会返回引用,当服务恢复时,能自动连上。

能够经过check="false"关闭检查,好比,测试时,有些服务不关心,或者出现了循环依赖,必须有一方先启动。

1、关闭某个服务的启动时检查:(没有提供者时报错)
<dubbo:reference interface="com.foo.BarService" check="false" />

2、关闭全部服务的启动时检查:(没有提供者时报错)  写在定义服务消费者一方
<dubbo:consumer check="false" />

3、关闭注册中心启动时检查:(注册订阅失败时报错)
<dubbo:registry check="false" />

引用缺省是延迟初始化的,只有引用被注入到其它Bean,或被getBean()获取,才会初始化。
若是须要饥饿加载,即没有人引用也当即生成动态代理,能够配置:

<dubbo:reference interface="com.foo.BarService" init="true" />

订阅

一、问题
为方便开发测试,常常会在线下共用一个全部服务可用的注册中心,这时,若是一个正在开发中的服务提供者注册,可能会影响消费者不能正常运行。

二、解决方案
可让服务提供者开发方,只订阅服务(开发的服务可能依赖其它服务),而不注册正在开发的服务,经过直连测试正在开发的服务。

禁用注册配置:
<dubbo:registry address="10.20.153.10:9090" register="false" />
或者:
<dubbo:registry address="10.20.153.10:9090?register=false" />

回声检测

回声测试用于检测服务是否可用,回声测试按照正常请求流程执行,可以测试整个调用是否通畅,可用于监控。
全部服务自动实现EchoService接口,只需将任意服务引用强制转型为EchoService,便可使用。

<dubbo:reference id="memberService" interface="com.xxx.MemberService" />

MemberService memberService = ctx.getBean("memberService"); // 远程服务引用
EchoService echoService = (EchoService) memberService; // 强制转型为EchoService
String status = echoService.$echo("OK"); // 回声测试可用性
assert(status.equals("OK"))

延迟连接

延迟链接,用于减小长链接数,当有调用发起时,再建立长链接。
只对使用长链接的dubbo协议生效。

<dubbo:protocol name="dubbo" lazy="true" />

令牌验证

防止消费者绕过注册中心访问提供者,在注册中心控制权限,以决定要不要下发令牌给消费者,注册中心可灵活改变受权方式,而不需修改或升级提供者

1、全局设置开启令牌验证:
<!--随机token令牌,使用UUID生成-->
<dubbo:provider interface="com.foo.BarService" token="true" />

<!--固定token令牌,至关于密码-->
<dubbo:provider interface="com.foo.BarService" token="123456" />

2、服务级别设置开启令牌验证:
<!--随机token令牌,使用UUID生成-->
<dubbo:service interface="com.foo.BarService" token="true" />

<!--固定token令牌,至关于密码-->
<dubbo:service interface="com.foo.BarService" token="123456" />

3、协议级别设置开启令牌验证:
<!--随机token令牌,使用UUID生成-->
<dubbo:protocol name="dubbo" token="true" />

<!--固定token令牌,至关于密码-->
<dubbo:protocol name="dubbo" token="123456" />

日志适配

缺省自动查找:log4j、slf4j、jcl、jdk

能够经过如下方式配置日志输出策略:dubbo:application logger="log4j"/>

访问日志:
若是你想记录每一次请求信息,可开启访问日志,相似于apache的访问日志。此日志量比较大,请注意磁盘容量。

将访问日志输出到当前应用的log4j日志:

<dubbo:protocol accesslog="true" />

将访问日志输出到指定文件:

<dubbo:protocol accesslog="http://10.20.160.198/wiki/display/dubbo/foo/bar.log" />

配置缓存文件

配置方法以下:

<dubbo:registryfile=”${user.home}/output/dubbo.cache” />

注意:
文件的路径,应用能够根据须要调整,保证这个文件不会在发布过程当中被清除。若是有多个应用进程注意不要使用同一个文件,避免内容被覆盖。

这个文件会缓存:
注册中心的列表
服务提供者列表

有了这项配置后,当应用重启过程当中,Dubbo注册中心不可用时则应用会从这个缓存文件读取服务提供者列表的信息,进一步保证应用可靠性。

dubbo常见问题

dubbo-admin没法显示Group分组信息

http://blog.csdn.net/xlgen157387/article/details/50345545

没法访问远程Zookeeper已注册服务的问题

 http://blog.csdn.net/xlgen157387/article/details/50385266

dubbo源码

源码地址 

http://dangdangdotcom.github.io/dubbox

源码结构

Dubbo以包结构来组织各个模块,各个模块及其关系,如图所示:

这里写图片描述

dubbo-common 公共逻辑模块,包括Util类和通用模型。

dubbo-remoting 远程通信模块,至关于Dubbo协议的实现,若是RPC用RMI协议则不须要使用此包。

dubbo-rpc 远程调用模块,抽象各类协议,以及动态代理,只包含一对一的调用,不关心集群的管理。

dubbo-cluster 集群模块,将多个服务提供方假装为一个提供方,包括:负载均衡、容错、路由等,集群的地址列表能够是静态配置的,也能够是由注册中心下发。

dubbo-registry 注册中心模块,基于注册中心下发地址的集群方式,以及对各类注册中心的抽象。

dubbo-monitor 监控模块,统计服务调用次数,调用时间的,调用链跟踪的服务。

dubbo-config 配置模块,是Dubbo对外的API,用户经过Config使用Dubbo,隐藏Dubbo全部细节。

dubbo-container 容器模块,是一个Standalone的容器,以简单的Main加载Spring启动,由于服务一般不须要Tomcat/JBoss等Web容器的特性,不必用Web容器去加载服务。
相关文章
相关标签/搜索