初识Dubbo 系列之7-Dubbo 示例
来源:程序员人生 发布时间:2015-05-15 08:19:47 阅读次数:3392次
示例
|
想完全的运行起来,请参见:快速启动 (+),这里只列出各种场景的配置方式 |
|
以下示例全部使用基于Spring的Xml配置 (+)作为参考,如果不想使用Spring,而希望通过API的方式进行调用,请参见:API配置
(+) |
启动时检查
(+) (#)
|
Dubbo缺省会在启动时检查依赖的服务是不是可用,不可用时会抛出异常,禁止Spring初始化完成,以便上线时,能尽早发现问题,默许check=true。 |
|
如果你的Spring容器是懒加载的,或通过API编程延迟援用服务,请关闭check,否则服务临时不可用时,会抛出异常,拿到null援用,如果check=false,总是会返回援用,当服务恢复时,能自动连上。 |
可以通过check="false"关闭检查,比如,测试时,有些服务不关心,或出现了循环依赖,必须有1方先启动。
关闭某个服务的启动时检查:(没有提供者时报错)
< dubbo:reference interface = "com.foo.BarService" check = "false" />
|
关闭所有服务的启动时检查:(没有提供者时报错)
< dubbo:consumer check = "false" />
|
关闭注册中心启动时检查:(注册定阅失败时报错)
< dubbo:registry check = "false" />
|
也能够用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:reference interface = "com.foo.BarService" init = "true" />
|
生活不易,码农辛苦
如果您觉得本网站对您的学习有所帮助,可以手机扫描二维码进行捐赠