dubbo官方文档node
项目的规模愈来愈大,总得解耦,不能在一个项目里,这时候,公司采用了dubbo做为分布式应用,将多项业务拆分,并作了库存服务统1、价格服务统一等等一些特殊须要统一性的服务。算法
做为dubbo我也接触了快一年的时间,总会有一些本身的对dubbo的想法。spring
下面是对dubbo的说明:数据库
节点角色说明:
Provider: 暴露服务的服务提供方。
Consumer: 调用远程服务的服务消费方。
Registry: 服务注册与发现的注册中心。
Monitor: 统计服务的调用次调和调用时间的监控中心。
Container: 服务运行容器。
调用关系说明:
0. 服务容器负责启动,加载,运行服务提供者。
1. 服务提供者在启动时,向注册中心注册本身提供的服务。
2. 服务消费者在启动时,向注册中心订阅本身所需的服务。
3. 注册中心返回服务提供者地址列表给消费者,若是有变动,注册中心将基于长链接推送变动数据给消费者。
4. 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,若是调用失败,再选另外一台调用。
5. 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。
(1) 连通性:
注册中心负责服务地址的注册与查找,至关于目录服务,服务提供者和消费者只在启动时与注册中心交互,注册中心不转发请求,压力较小
监控中心负责统计各服务调用次数,调用时间等,统计先在内存汇总后每分钟一次发送到监控中心服务器,并以报表展现
服务提供者向注册中心注册其提供的服务,并汇报调用时间到监控中心,此时间不包含网络开销
服务消费者向注册中心获取服务提供者地址列表,并根据负载算法直接调用提供者,同时汇报调用时间到监控中心,此时间包含网络开销
注册中心,服务提供者,服务消费者三者之间均为长链接,监控中心除外
注册中心经过长链接感知服务提供者的存在,服务提供者宕机,注册中心将当即推送事件通知消费者
注册中心和监控中心所有宕机,不影响已运行的提供者和消费者,消费者在本地缓存了提供者列表
注册中心和监控中心都是可选的,服务消费者能够直连服务提供者
(2) 健状性:api监控中心宕掉不影响使用,只是丢失部分采样数据
数据库宕掉后,注册中心仍能经过缓存提供服务列表查询,但不能注册新服务
注册中心对等集群,任意一台宕掉后,将自动切换到另外一台
注册中心所有宕掉后,服务提供者和服务消费者仍能经过本地缓存通信
服务提供者无状态,任意一台宕掉后,不影响使用
服务提供者所有宕掉后,服务消费者应用将没法使用,并没有限次重连等待服务提供者恢复
(3) 伸缩性:缓存注册中心为对等集群,可动态增长机器部署实例,全部客户端将自动发现新的注册中心
服务提供者无状态,可动态增长机器部署实例,注册中心将推送新的服务提供者信息给消费者
(4) 升级性:服务器当服务集群规模进一步扩大,带动IT治理结构进一步升级,须要实现动态部署,进行流动计算,现有分布式服务架构不会带来阻力
当zookeeper挂掉了,其实dubbo的消费者也能访问生产者,由于项目在启动的时候,会去主动拉取全部生产者的地址端口等数据。每次消费者应用访问的时候首先是从本地地址缓存中读取。网络
服务提供方调试:架构
<!-- 提供方应用信息,用于计算依赖关系 -->
<dubbo:application name="hello-world-app" />并发<!-- 使用zookeeper注册中心暴露服务地址 -->
<dubbo:registry address="zookeeper://224.5.6.7:1234" /><!-- 用dubbo协议在20880端口暴露服务 这个端口可用于点对点调试-->
<dubbo:protocol name="dubbo" port="20880" /><!-- 声明须要暴露的服务接口 -->
<dubbo:service interface="com.alibaba.dubbo.demo.DemoService" ref="demoService" /><!-- 和本地bean同样实现服务 -->
<bean id="demoService" class="com.alibaba.dubbo.demo.provider.DemoServiceImpl" />
服务消费方配置:
<!-- 消费方应用名,用于计算依赖关系,不是匹配条件,不要与提供方同样 -->
<dubbo:application name="consumer-of-helloworld-app" /><!-- 使用zookeeper注册中心暴露发现服务地址 -->
<dubbo:registry address="zookeeper://224.5.6.7:1234" /><!-- 生成远程服务代理,能够和本地bean同样使用demoService -->
<dubbo:reference id="demoService" interface="com.alibaba.dubbo.demo.DemoService" />
官方给的文档能够根据包直接扫描包下含com.alibaba.dubbo.config.annotation.Service注直接解的类,但通常不采用这个,通常都是在xml文件里面配,由于这样能够清楚的看到你配的全部dubbo服务提供方接口以及接口的限制条件
<!-- 扫描注解包路径,多个包用逗号分隔,不填pacakge表示扫描当前ApplicationContext中全部的类 -->
<dubbo:annotation package="com.foo.bar.service" />
经常使用消费者的属性
<!-- 服务启动关闭对该服务提供者的接口是否正常的监测,也就是BarService是否能够正常调用不影响本应用的启动,当为true的时候若是该接口挂了,本应用就起不起来了-->
<dubbo:reference interface="com.foo.BarService" check="false" /><!-- 关闭全部服务的启动时检查 -->
<dubbo:consumer check="false" /><!-- 配置重试次数,最好只用于读的重试,写操做可能会引发屡次写入 下面三个任意一个配置就行 默认retries="0"-->
<dubbo:service retries="2" />
<dubbo:reference retries="2" />
<dubbo:reference>
<dubbo:method name="findFoo" retries="2" />
</dubbo:reference>
dubbo调用服务的负载均衡,最后一种比较适合短期内大量参数同样的请求
Random LoadBalance
随机,按权重设置随机几率。
在一个截面上碰撞的几率高,但调用量越大分布越均匀,并且按几率使用权重后也比较均匀,有利于动态调整提供者权重。
RoundRobin LoadBalance
轮循,按公约后的权重设置轮循比率。
存在慢的提供者累积请求问题,好比:第二台机器很慢,但没挂,当请求调到第二台时就卡在那,长此以往,全部请求都卡在调到第二台上。
LeastActive LoadBalance
最少活跃调用数,相同活跃数的随机,活跃数指调用先后计数差。
使慢的提供者收到更少请求,由于越慢的提供者的调用先后计数差会越大。
ConsistentHash LoadBalance
一致性Hash,相同参数的请求老是发到同一提供者。
当某一台提供者挂时,本来发往该提供者的请求,基于虚拟节点,平摊到其它提供者,不会引发剧烈变更。
算法参见:http://en.wikipedia.org/wiki/Consistent_hashing。
缺省只对第一个参数Hash,若是要修改,请配置<dubbo:parameter key="hash.arguments" value="0,1" />
缺省用160份虚拟节点,若是要修改,请配置<dubbo:parameter key="hash.nodes" value="320" />
配置如:
<dubbo:service interface="..." loadbalance="roundrobin" />
或:<dubbo:reference interface="..." loadbalance="roundrobin" />
或:<dubbo:service interface="...">
<dubbo:method name="..." loadbalance="roundrobin"/>
</dubbo:service>
或:<dubbo:reference interface="...">
<dubbo:method name="..." loadbalance="roundrobin"/>
</dubbo:reference>
事件处理线程说明
若是事件处理的逻辑能迅速完成,而且不会发起新的IO请求,好比只是在内存中记个标识,则直接在IO线程上处理更快,由于减小了线程池调度。
但若是事件处理逻辑较慢,或者须要发起新的IO请求,好比须要查询数据库,则必须派发到线程池,不然IO线程阻塞,将致使不能接收其它请求。
若是用IO线程处理事件,又在事件处理过程当中发起新的IO请求,好比在链接事件中发起登陆请求,会报“可能引起死锁”异常,但不会真死锁。
Dispatcher
all 全部消息都派发到线程池,包括请求,响应,链接事件,断开事件,心跳等。
direct 全部消息都不派发到线程池,所有在IO线程上直接执行。
message 只有请求响应消息派发到线程池,其它链接断开事件,心跳等消息,直接在IO线程上执行。
execution 只请求消息派发到线程池,不含响应,响应和其它链接断开事件,心跳等消息,直接在IO线程上执行。
connection 在IO线程上,将链接断开事件放入队列,有序逐个执行,其它消息派发到线程池。
ThreadPool
fixed 固定大小线程池,启动时创建线程,不关闭,一直持有。(缺省)
cached 缓存线程池,空闲一分钟自动删除,须要时重建。
limited 可伸缩线程池,但池中的线程数只会增加不会收缩。(为避免收缩时忽然来了大流量引发的性能问题)。
配置如:
<dubbo:protocol name="dubbo" dispatcher="all" threadpool="fixed" threads="100" />
下面这个配置能够形成服务提供方只订阅不向注册中心注册
为方便开发测试,常常会在线下共用一个全部服务可用的注册中心,这时,若是一个正在开发中的服务提供者注册,可能会影响消费者不能正常运行。
禁用注册配置:
<dubbo:registry address="10.20.153.10:9090" register="false" />
或者:
<dubbo:registry address="10.20.153.10:9090?register=false" />
下面这个配置能够形成服务消费方只注册不向注册中心订阅
若是有两个镜像环境,两个注册中心,有一个服务只在其中一个注册中心有部署,另外一个注册中心还没来得及部署,而两个注册中心的其它应用都须要依赖此服务,因此须要将服务同时注册到两个注册中心,但却不能让此服务同时依赖两个注册中心的其它服务。
禁用订阅配置:<dubbo:registry id="hzRegistry" address="10.20.153.10:9090" />
<dubbo:registry id="qdRegistry" address="10.20.141.150:9090" subscribe="false" />
或者:
<dubbo:registry id="hzRegistry" address="10.20.153.10:9090" />
<dubbo:registry id="qdRegistry" address="10.20.141.150:9090?subscribe=false" />
不一样服务在性能上适用不一样协议进行传输,好比大数据用短链接协议,小数据大并发用长链接协议。
<dubbo:application name="world" />
<dubbo:registry id="registry" address="10.20.141.150:9090" username="admin" password="hello1234" /><!-- 多协议配置 -->
<dubbo:protocol name="dubbo" port="20880" />
<dubbo:protocol name="rmi" port="1099" /><!-- 使用dubbo协议暴露服务 -->
<dubbo:service interface="com.alibaba.hello.api.HelloService" version="1.0.0" ref="helloService" protocol="dubbo" />
<!-- 使用rmi协议暴露服务 -->
<dubbo:service interface="com.alibaba.hello.api.DemoService" version="1.0.0" ref="demoService" protocol="rmi" />
<!-- 使用多个协议暴露服务 -->
<dubbo:service id="helloService" interface="com.alibaba.hello.api.HelloService" version="1.0.0" protocol="dubbo,hessian" />
多注册中心
中文站有些服务来不及在青岛部署,只在杭州部署,而青岛的其它应用须要引用此服务,就能够将服务同时注册到两个注册中心。
<dubbo:application name="world" />
<!-- 多注册中心配置 -->
<dubbo:registry id="hangzhouRegistry" address="10.20.141.150:9090" />
<dubbo:registry id="qingdaoRegistry" address="10.20.141.151:9010" default="false" /><!-- 向多个注册中心注册 -->
<dubbo:service interface="com.alibaba.hello.api.HelloService" version="1.0.0" ref="helloService" registry="hangzhouRegistry,qingdaoRegistry" />CRM有些服务是专门为国际站设计的,有些服务是专门为中文站设计的。
<dubbo:application name="world" /><!-- 多注册中心配置 -->
<dubbo:registry id="chinaRegistry" address="10.20.141.150:9090" />
<dubbo:registry id="intlRegistry" address="10.20.154.177:9010" default="false" /><!-- 向中文站注册中心注册 -->
<dubbo:service interface="com.alibaba.hello.api.HelloService" version="1.0.0" ref="helloService" registry="chinaRegistry" /><!-- 向国际站注册中心注册 -->
<dubbo:service interface="com.alibaba.hello.api.DemoService" version="1.0.0" ref="demoService" registry="intlRegistry" />
当一个接口有多种实现时,能够用group区分。
<dubbo:service group="feedback" interface="com.xxx.IndexService" />
<dubbo:service group="member" interface="com.xxx.IndexService" />
<dubbo:reference id="feedbackIndexService" group="feedback" interface="com.xxx.IndexService" />
<dubbo:reference id="memberIndexService" group="member" interface="com.xxx.IndexService" />
任意组:(2.2.0以上版本支持,老是只调一个可用组的实现)
<dubbo:reference id="barService" interface="com.foo.BarService" group="*" />当一个接口实现,出现不兼容升级时,能够用版本号过渡,版本号不一样的服务相互间不引用。
在低压力时间段,先升级一半提供者为新版本
再将全部消费者升级为新版本
而后将剩下的一半提供者升级为新版本<dubbo:service interface="com.foo.BarService" version="1.0.0" />
<dubbo:service interface="com.foo.BarService" version="2.0.0" />
<dubbo:reference id="barService" interface="com.foo.BarService" version="1.0.0" />
<dubbo:reference id="barService" interface="com.foo.BarService" version="2.0.0" />不区分版本:(2.2.0以上版本支持)
<dubbo:reference id="barService" interface="com.foo.BarService" version="*" />按组合并返回结果,好比菜单服务,接口同样,但有多种实现,用group区分,如今消费方需从每种group中调用一次返回结果,合并结果返回,这样就能够实现聚合菜单项。比较鸡肋,小点的项目应该都用不到
配置如:(搜索全部分组)
<dubbo:reference interface="com.xxx.MenuService" group="*" merger="true" />
(合并指定分组)
<dubbo:reference interface="com.xxx.MenuService" group="aaa,bbb" merger="true" />(指定方法合并结果,其它未指定的方法,将只调用一个Group)
<dubbo:reference interface="com.xxx.MenuService" group="*">
<dubbo:method name="getMenuItems" merger="true" />
</dubbo:service>(某个方法不合并结果,其它都合并结果)
<dubbo:reference interface="com.xxx.MenuService" group="*" merger="true">
<dubbo:method name="getMenuItems" merger="false" />
</dubbo:service>(指定合并策略,缺省根据返回值类型自动匹配,若是同一类型有两个合并器时,需指定合并器的名称)
<dubbo:reference interface="com.xxx.MenuService" group="*">
<dubbo:method name="getMenuItems" merger="mymerge" />
</dubbo:service>(指定合并方法,将调用返回结果的指定方法进行合并,合并方法的参数类型必须是返回结果类型自己)
<dubbo:reference interface="com.xxx.MenuService" group="*">
<dubbo:method name="getMenuItems" merger=".addAll" />
</dubbo:service>
dubbo 参数验证
字段验证
@NotNull // 不容许为空
@Size(min = 1, max = 20) // 长度或大小范围
private String name;@NotNull(groups = ValidationService.Save.class) // 保存时不容许为空,更新时容许为空 ,表示不更新该字段
@Pattern(regexp = "^\\s*\\w+(?:\\.{0,1}[\\w-]+)*@[a-zA-Z0-9]+(?:[-.][a-zA-Z0-9]+)*\\.[a-zA-Z]+\\s*$")
private String email;@Min(18) // 最小值
@Max(100) // 最大值
private int age;@Past // 必须为一个过去的时间
private Date loginDate;@Future // 必须为一个将来的时间
private Date expiryDate;分组验证示例:
//下面这个验证应该是用于做用在参数类属性上的时候,当被调用的方法属于ValidationService接口的时候校验不为空
// 缺省可按服务接口区分验证场景,如:@NotNull(groups = ValidationService.class)
public interface ValidationService {//下面这个验证应该是用于做用在参数类属性上的时候,当被调用的方法属于ValidationService接口的save方法的时候校验不为空
@interface Save{} // 与方法同名接口,首字母大写,用于区分验证场景,如:@NotNull(groups = ValidationService.Save.class),可选
void save(ValidationParameter parameter);@interface Update{} // 与方法同名接口,首字母大写,用于区分验证场景,如:@NotNull(groups = ValidationService.Update.class),可选
void update(ValidationParameter parameter);void delete(@Min(1) long id, @NotNull @Size(min = 2, max = 16) @Pattern(regexp = "^[a-zA-Z]+$") String operator);
}
关联验证示例:
public interface ValidationService {//下面这个验证应该是指该方法的调用参数必须知足Update组合Save组验证规则
@GroupSequence(Update.class) // 同时验证Update组规则
@interface Save{}
void save(ValidationParameter parameter);@interface Update{}
void update(ValidationParameter parameter);}
在客户端验证参数:
<dubbo:reference id="validationService" interface="com.alibaba.dubbo.examples.validation.api.ValidationService" validation="true" />在服务器端验证参数:
<dubbo:service interface="com.alibaba.dubbo.examples.validation.api.ValidationService" ref="validationService" validation="true" />
dubbo的令牌验证
防止消费者绕过注册中心访问提供者
在注册中心控制权限,以决定要不要下发令牌给消费者
注册中心可灵活改变受权方式,而不需修改或升级提供者
能够全局设置开启令牌验证:<!--随机token令牌,使用UUID生成-->
<dubbo:provider interface="com.foo.BarService" token="true" />
<!--固定token令牌,至关于密码-->
<dubbo:provider interface="com.foo.BarService" token="123456" />
也可在服务级别设置:<!--随机token令牌,使用UUID生成-->
<dubbo:service interface="com.foo.BarService" token="true" />
<!--固定token令牌,至关于密码-->
<dubbo:service interface="com.foo.BarService" token="123456" />
dubbo经常使用配置:
<dubbo:service> version version string 可选 0.0.0 服务发现 服务版本,建议使用两位数字版本,如:1.0,一般在接口不兼容时版本号才须要升级<dubbo:service> group group string 可选 服务发现 服务分组,当一个接口有多个实现,能够用分组区分
//主要由于dubbo服务在spring2.X初始化全部类以前被暴露出去,致使被请求锁死了singletonObjects、beanDefinitionMap
<dubbo:service> delay delay int 可选 0 性能调优 延迟注册服务时间(毫秒) ,设为-1时,表示延迟到Spring容器初始化完成时暴露服务<dubbo:service> timeout timeout int 可选 1000 性能调优 远程服务调用超时时间(毫秒)
<dubbo:service> retries retries int 可选 2 性能调优 远程服务调用重试次数,不包括第一次调用,不须要重试请设为0
//这里应该还有个一致性Hash的方式,文档介绍有,可是配置文档没有。
<dubbo:service> loadbalance loadbalance string 可选 random 性能调优 负载均衡策略,可选值:random,roundrobin,leastactive,分别表示:随机,轮循,最少活跃调用<dubbo:service> token token string/boolean 可选 false 服务治理 令牌验证,为空表示不开启,若是为true,表示随机生成动态令牌,不然使用静态令牌,令牌的做用是防止消费者绕过注册中心直接访问,保证注册中心的受权功能有效,若是使用点对点调用,需关闭令牌功能
<dubbo:service> registry string 可选 缺省向全部registry注册 配置关联 向指定注册中心注册,在多个注册中心时使用,值为<dubbo:registry>的id属性,多个注册中心ID用逗号分隔,若是不想将该服务注册到任何registry,可将值设为N/A
<dubbo:service> provider string 可选 缺使用第一个provider配置 配置关联 指定provider,值为<dubbo:provider>的id属性
<dubbo:service> dynamic dynamic boolean 可选 true 服务治理 服务是否动态注册,若是设为false,注册后将显示后disable状态,需人工启用,而且服务提供者中止时,也不会自动取消册,需人工禁用。
<dubbo:service> cluster cluster string 可选 failover 性能调优 集群方式,可选:failover/failfast/failsafe/failback/forking
<dubbo:service> register register boolean 可选 true 服务治理 该协议的服务是否注册到注册中心
<dubbo:service> owner owner string 可选 服务治理 服务负责人,用于服务治理,请填写负责人公司邮箱前缀
<dubbo:reference> version version string 可选 服务发现 服务版本,与服务提供者的版本一致<dubbo:reference> group group string 可选 服务发现 服务分组,当一个接口有多个实现,能够用分组区分,必需和服务提供方一致
<dubbo:reference> timeout timeout long 可选 缺省使用<dubbo:consumer>的timeout 性能调优 服务方法调用超时时间(毫秒)
<dubbo:reference> retries retries int 可选 缺省使用<dubbo:consumer>的retries 性能调优 远程服务调用重试次数,不包括第一次调用,不须要重试请设为0
<dubbo:reference> loadbalance loadbalance string 可选 缺省使用<dubbo:consumer>的loadbalance 性能调优 负载均衡策略,可选值:random,roundrobin,leastactive,分别表示:随机,轮循,最少活跃调用
<dubbo:reference> check check boolean 可选 缺省使用<dubbo:consumer>的check 服务治理 启动时检查提供者是否存在,true报错,false忽略
<dubbo:reference> url <url> string 可选 服务治理 点对点直连服务提供者地址,将绕过注册中心
<dubbo:reference> cache cache string/boolean 可选 服务治理 以调用参数为key,缓存返回结果,可选:lru, threadlocal, jcache等
<dubbo:reference> validation validation boolean 可选 服务治理 是否启用JSR303标准注解验证,若是启用,将对方法参数上的注解进行校验
<dubbo:reference> registry string 可选 缺省将从全部注册中心获服务列表后合并结果 配置关联 从指定注册中心注册获取服务列表,在多个注册中心时使用,值为<dubbo:registry>的id属性,多个注册中心ID用逗号分隔
<dubbo:reference> owner owner string 可选 服务治理 调用服务负责人,用于服务治理,请填写负责人公司邮箱前缀
<dubbo:protocol> id string 可选 dubbo 配置关联 协议BeanId,能够在<dubbo:service protocol="">中引用此ID,若是ID不填,缺省和name属性值同样,重复则在name后加序号<dubbo:protocol> name <protocol> string 必填 dubbo 性能调优 协议名称
<dubbo:protocol> port <port> int 可选 dubbo协议缺省端口为20880,rmi协议缺省端口为1099,http和hessian协议缺省端口为80
若是配置为-1 或者 没有配置port,则会分配一个没有被占用的端口。Dubbo 2.4.0+,分配的端口在协议缺省端口的基础上增加,确保端口段可控。 服务发现 服务端口<dubbo:protocol> threadpool threadpool string 可选 fixed 性能调优 线程池类型,可选:fixed/cached
<dubbo:protocol> heartbeat heartbeat int 可选 0 性能调优 心跳间隔,对于长链接,当物理层断开时,好比拔网线,TCP的FIN消息来不及发送,对方收不到断开事件,此时须要心跳来帮助检查链接是否已断开
<dubbo:protocol> register register boolean 可选 true 服务治理 该协议的服务是否注册到注册中心
<dubbo:registry> id string 可选 配置关联 注册中心引用BeanId,能够在<dubbo:service registry="">或<dubbo:reference registry="">中引用此ID<dubbo:registry> address <host:port> string 必填 服务发现 注册中心服务器地址,若是地址没有端口缺省为9090,同一集群内的多个地址用逗号分隔,如:ip:port,ip:port,不一样集群的注册中心,请配置多个<dubbo:registry>标签
<dubbo:registry> protocol <protocol> string 可选 dubbo 服务发现 注同中心地址协议,支持dubbo, http, local三种协议,分别表示,dubbo地址,http地址,本地注册中心
<dubbo:registry> port <port> int 可选 9090 服务发现 注册中心缺省端口,当address没有带端口时使用此端口作为缺省值
<dubbo:registry> username <username> string 可选 服务治理 登陆注册中心用户名,若是注册中心不须要验证可不填
<dubbo:registry> password <password> string 可选 服务治理 登陆注册中心密码,若是注册中心不须要验证可不填
<dubbo:registry> timeout registry.timeout int 可选 5000 性能调优 注册中心请求超时时间(毫秒)
<dubbo:registry> check check boolean 可选 true 服务治理 注册中心不存在时,是否报错
<dubbo:registry> register register boolean 可选 true 服务治理 是否向此注册中心注册服务,若是设为false,将只订阅,不注册
<dubbo:registry> subscribe subscribe boolean 可选 true 服务治理 是否向此注册中心订阅服务,若是设为false,将只注册,不订阅
<dubbo:application> name application string 必填 服务治理 当前应用名称,用于注册中心计算应用间依赖关系,注意:消费者和提供者应用名不要同样,此参数不是匹配条件,你当前项目叫什么名字就填什么,和提供者消费者角色无关,好比:kylin应用调用了morgan应用的服务,则kylin项目配成kylin,morgan项目配成morgan,可能kylin也提供其它服务给别人使用,但kylin项目永远配成kylin,这样注册中心将显示kylin依赖于morgan
标签 属性 对应URL参数 类型 是否必填 缺省值 做用 描述 兼容性
<dubbo:application> name application string 必填 服务治理 当前应用名称,用于注册中心计算应用间依赖关系,注意:消费者和提供者应用名不要同样,此参数不是匹配条件,你当前项目叫什么名字就填什么,和提供者消费者角色无关,好比:kylin应用调用了morgan应用的服务,则kylin项目配成kylin,morgan项目配成morgan,可能kylin也提供其它服务给别人使用,但kylin项目永远配成kylin,这样注册中心将显示kylin依赖于morgan 1.0.16以上版本<dubbo:application> version application.version string 可选 服务治理 当前应用的版本
这两个标签感受没什么特殊的,应该是能够配一些共通的配置在service和reference上使用而已。
注册中心上通常采用zookeeper做为注册中心,阿里内部并无采用Zookeeper作为注册中心,而是使用本身实现的基于数据库的注册中心,即:Zookeeper注册中心并无在阿里内部长时间运行的可靠性保障,此Zookeeper桥接实现只为开源版本提供,其可靠性依赖于Zookeeper自己的可靠性。
dubbo所有的配置信息都看了一遍,受益良多,发现了不少平时没注意的地方。你们得多看看官方文档。