国内最全IT社区平台 联系我们 | 收藏本站
华晨云阿里云优惠2
您当前位置:首页 > php框架 > 框架设计 > 初识Dubbo 系列之7-Dubbo 示例

初识Dubbo 系列之7-Dubbo 示例

来源:程序员人生   发布时间:2015-05-15 08:19:47 阅读次数:3437次

示例

想完全的运行起来,请参见:快速启动 (+),这里只列出各种场景的配置方式
以下示例全部使用基于Spring的Xml配置 (+)作为参考,如果不想使用Spring,而希望通过API的方式进行调用,请参见:API配置 (+)

启动时检查

(+) (#)

Dubbo缺省会在启动时检查依赖的服务是不是可用,不可用时会抛出异常,禁止Spring初始化完成,以便上线时,能尽早发现问题,默许check=true。
如果你的Spring容器是懒加载的,或通过API编程延迟援用服务,请关闭check,否则服务临时不可用时,会抛出异常,拿到null援用,如果check=false,总是会返回援用,当服务恢复时,能自动连上。

可以通过check="false"关闭检查,比如,测试时,有些服务不关心,或出现了循环依赖,必须有1方先启动。

关闭某个服务的启动时检查:(没有提供者时报错)

<dubbo:referenceinterface="com.foo.BarService"check="false"/>

关闭所有服务的启动时检查:(没有提供者时报错)

<dubbo:consumercheck="false"/>

关闭注册中心启动时检查:(注册定阅失败时报错)

<dubbo:registrycheck="false"/>

也能够用dubbo.properties配置:

dubbo.properties
dubbo.reference.com.foo.BarService.check=false
dubbo.reference.check=false
dubbo.consumer.check=false
dubbo.registry.check=false

也能够用-D参数:

java -Ddubbo.reference.com.foo.BarService.check=false
java -Ddubbo.reference.check=false
java -Ddubbo.consumer.check=false
java -Ddubbo.registry.check=false
注意区分
  • dubbo.reference.check=false,强迫改变所有reference的check值,就算配置中有声明,也会被覆盖。
  • dubbo.consumer.check=false,是设置check的缺省值,如果配置中有显式的声明,如:<dubbo:reference check="true"/>,不会受影响。
  • dubbo.registry.check=false,前面两个都是指定阅成功,但提供者列表是不是为空是不是报错,如果注册定阅失败时,也允许启动,需使用此选项,将在后台定时重试。

援用缺省是延迟初始化的,只有援用被注入到其它Bean,或被getBean()获得,才会初始化。
如果需要饥饿加载,即没有人援用也立即生成动态代理,可以配置:

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


生活不易,码农辛苦
如果您觉得本网站对您的学习有所帮助,可以手机扫描二维码进行捐赠
程序员人生
------分隔线----------------------------
分享到:
------分隔线----------------------------
关闭
程序员人生