一、配置

<!-- Dubbo -->
<dependency>
   <groupId>com.alibaba</groupId>
   <artifactId>dubbo</artifactId>
   <version>${dubbo.version}</version>
   <!--<exclusions>-->
      <!--<exclusion>-->
         <!--<groupId>org.springframework</groupId>-->
         <!--<artifactId>spring</artifactId>-->
      <!--</exclusion>-->
      <!--<exclusion>-->
         <!--<groupId>org.jboss.netty</groupId>-->
         <!--<artifactId>netty</artifactId>-->
      <!--</exclusion>-->
   <!--</exclusions>-->
</dependency>
<dependency>
   <groupId>org.apache.zookeeper</groupId>
   <artifactId>zookeeper</artifactId>
   <version>${zookeeper.version}</version>
   <!--<exclusions>-->
      <!--<exclusion>-->
         <!--<groupId>org.slf4j</groupId>-->
         <!--<artifactId>slf4j-log4j12</artifactId>-->
      <!--</exclusion>-->
   <!--</exclusions>-->
</dependency>
服务端配置:
<?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-4.0.xsd
               http://code.alibabatech.com/schema/dubbo
               http://code.alibabatech.com/schema/dubbo/dubbo.xsd ">

    <!-- 提供方应用名称信息,这个相当于起一个名字,我们dubbo管理页面比较清晰是哪个应用暴露出来的 -->
    <dubbo:application name="test-sys-service"/>
    <!-- 使用zookeeper注册中心暴露服务地址 -->
    <dubbo:registry address="zookeeper://127.0.0.1:2181" check="false"
                    timeout="20000" file="/output/cache/test-sys-service.cache"/>
    <!-- 用dubbo协议在20880端口暴露服务 -->
    <dubbo:protocol name="dubbo" port="8085" threads="100"/>
    <!-- 服务端要暴露的服务接口,注解@com.alibaba.dubbo.config.annotation.Service -->
    <dubbo:annotation package="com.ibase4jTest"/>
    <!-- 服务消费端配置 -->
    <dubbo:consumer timeout="20000" check="false" loadbalance="leastactive" retries="0"/>
</beans>
服务端接口:
package com.ibase4jTest.core;

import com.alibaba.dubbo.config.annotation.Service;
import com.ibase4jTest.provider.ISysProvider;

/**
 * Created by wuyujing on 2018/1/29.
 */
@Service(interfaceClass = ISysProvider.class)
public class SysProviderImpl implements ISysProvider {
}
客户端配置:
<?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-4.0.xsd
               http://code.alibabatech.com/schema/dubbo
               http://code.alibabatech.com/schema/dubbo/dubbo.xsd ">

    <!-- 提供方应用名称信息,这个相当于起一个名字,我们dubbo管理页面比较清晰是哪个应用暴露出来的 -->
    <dubbo:application name="test-sys-web"/>
    <!-- 使用zookeeper注册中心暴露服务地址 -->
    <dubbo:registry address="zookeeper://127.0.0.1:2181" check="false"
                    timeout="20000" file="/output/cache/test-sys-service.cache"/>
    <!-- 服务端要暴露的服务接口,注解@com.alibaba.dubbo.config.annotation.Service -->
    <dubbo:annotation package="com.ibase4jTest"/>

</beans>
客户端接口:
package com.ibase4jTest.core.shiro;

import com.alibaba.dubbo.config.annotation.Reference;
import com.ibase4jTest.provider.ISysProvider;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

/**
 * Created by wuyujing on 2018/1/24.
 */
public class Realm extends AuthorizingRealm {private final Logger logger = LogManager.getLogger();

    @Reference(interfaceClass = ISysProvider.class)private BaseProvider baseProvider;

}

二、分析

服务提供方调试:

<!-- 提供方应用信息,用于计算依赖关系 --><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请求,比如在连接事件中发起登录请求,会报“可能引发死锁”异常,但不会真死锁。Dispatcherall 所有消息都派发到线程池,包括请求,响应,连接事件,断开事件,心跳等。direct 所有消息都不派发到线程池,全部在IO线程上直接执行。message 只有请求响应消息派发到线程池,其它连接断开事件,心跳等消息,直接在IO线程上执行。execution 只请求消息派发到线程池,不含响应,响应和其它连接断开事件,心跳等消息,直接在IO线程上执行。connection 在IO线程上,将连接断开事件放入队列,有序逐个执行,其它消息派发到线程池。ThreadPoolfixed 固定大小线程池,启动时建立线程,不关闭,一直持有。(缺省)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全部的配置信息都看了一遍,受益良多,发现了很多平时没注意的地方。大家得多看看官方文档。

参考自http://blog.csdn.net/abcde474524573/article/details/53026110

dubbo 配置及分析相关推荐

  1. 精尽 Dubbo 源码分析 —— API 配置

    1. 概述 Dubbo 的配置目前提供了四种配置方式:1. API 配置 2. 属性配置 3. XML 配置 4. 注解配置 2. 配置一览 我们来看看 dubbo-config-api 的项目结构, ...

  2. 一次Dubbo拥堵的分析

    点击上方"方志朋",选择"设为星标" 回复"666"获取新整理的面试文章 作者:nxlhero https://blog.51cto.com ...

  3. Dubbo 源码分析 - 集群容错之 LoadBalance

    1.简介 LoadBalance 中文意思为负载均衡,它的职责是将网络请求,或者其他形式的负载"均摊"到不同的机器上.避免集群中部分服务器压力过大,而另一些服务器比较空闲的情况.通 ...

  4. Dubbo 源码分析 - 集群容错之 Cluster

    1.简介 为了避免单点故障,现在的应用至少会部署在两台服务器上.对于一些负载比较高的服务,会部署更多台服务器.这样,同一环境下的服务提供者数量会大于1.对于服务消费者来说,同一环境下出现了多个服务提供 ...

  5. Dubbo 源码分析 - 集群容错之 Router

    1. 简介 上一篇文章分析了集群容错的第一部分 – 服务目录 Directory.服务目录在刷新 Invoker 列表的过程中,会通过 Router 进行服务路由.上一篇文章关于服务路由相关逻辑没有细 ...

  6. Dubbo 源码分析 - 服务引用

    1. 简介 在上一篇文章中,我详细的分析了服务导出的原理.本篇文章我们趁热打铁,继续分析服务引用的原理.在 Dubbo 中,我们可以通过两种方式引用远程服务.第一种是使用服务直联的方式引用服务,第二种 ...

  7. Dubbo 源码分析 - 服务导出

    1.服务导出过程 本篇文章,我们来研究一下 Dubbo 导出服务的过程.Dubbo 服务导出过程始于 Spring 容器发布刷新事件,Dubbo 在接收到事件后,会立即执行服务导出逻辑.整个逻辑大致可 ...

  8. Dubbo配置加载问题

    问题引出,从dubbo2升级到了dubbo3版本,出现了一些消费方调用超时的现象,通过日志发现异常信息中的timeout竟然是1000ms,明明在暴漏接口的时候指定了超时时间,为什么没有生效. 经过d ...

  9. dubbo源码分析总结

    前言 在进行源码分析之前,我们先来通过一张图了解 Dubbo 服务调用过程. 首先服务消费者通过代理对象 Proxy 发起远程调用,接着通过网络客户端 Client 将编码后的请求发送给服务提供方的网 ...

最新文章

  1. 【奇淫巧技】XSS绕过技巧
  2. Machine Learning - Andrew Ng on Coursera (Week 2)
  3. 解决TIME_WAIT过多造成的问题
  4. [html] html和html5有什么区别呢?
  5. Android中实时视频传输(摄像头实时视频传输)解决方案二
  6. 使用maven开发javaweb项目
  7. 英语 面包为什么不可数?
  8. explict关键字
  9. python画图xlable显示中文_xlabel和ylabel超出绘图区域,无法在figu中完全显示
  10. 代理设置(wget/yum)
  11. 线性渐变和放射性渐变
  12. HDU多校练习第一场4608——I_Number
  13. 第7章第25节:双图排版:两张图片横竖交错叠加排版 [PowerPoint精美幻灯片实战教程]
  14. 计算机英语名词简释及省略解释
  15. 内外墙乳胶漆颜色怎么搭配,内外墙品牌涂料如何选购?
  16. 币圈的8大女神都是谁?-千氪
  17. C++ 函数- cout
  18. 关联数据赋能智能化业务
  19. 写在2014年7月2日
  20. VX Search Client 9.7.18 漏洞分析及利用

热门文章

  1. 一元运算符重载 前置和后置++ --(这种一般用成员函数来实现重载)
  2. JavaScript DOM 编程艺术 公用方法
  3. HTML5新标签 w3c
  4. 在Silverlight 和WPF中使用预编译指令 if..else..endif (译)
  5. 高级PHP应用程序漏洞审核技术
  6. win7如何删除mariadb
  7. Js获取当前系统时间,24小时制
  8. sparksql优化_Spark SQL amp; Streaming
  9. with pdo mysql_如何在PHP下开启PDO MySQL的扩展
  10. 《Android开发精要》读书笔记——Android的系统架构