4.1、配置原则
在服务提供者配置访问参数。因为服务提供者更了解服务的各种参数。
4.2、关闭检查
dubbo 缺省会在启动时检查依赖的服务是否可用,不可用时会抛出异常,阻止 Spring 初始化完成,以便上线时,能及早发现问题,默认 check=true。通过 check="false"关闭检查,比如,测试时,有些服务不关心,或者出现了循环依赖,必须有一方先启动。
例 1:关闭某个服务的启动时检查
<dubbo:reference interface=“com.foo.BarService” check=“false” />
例 2:关闭注册中心启动时检查
<dubbo:registry check=“false” />
默认启动服务时检查注册中心存在并已运行。注册中心不启动会报错。
4.3、重试次数
消费者访问提供者,如果访问失败,则切换重试访问其它服务器,但重试会带来更长延迟。访问时间变长,用户的体验较差。多次重新访问服务器有可能访问成功。可通过 retries=“2” 来设置重试次数(不含第一次)。
4.4、超时时间
由于网络或服务端不可靠,会导致调用出现一种不确定的中间状态(超时)。为了避免超时导致客户端资源(线程)挂起耗尽,必须设置超时时间。
timeout: 调用远程服务超时时间(毫秒)
4.4.1、Dubbo 服务消费者
<!-- 指定接口超时配置 -->
<dubbo:reference interface="com.foo.BarService" timeout="2000" />
4.4.2、Dubbo 服务提供者
<!-- 指定接口超时配置 -->
<dubbo:server interface="com.foo.BarService" timeout="2000" />
4.5、版本号
每个接口都应定义版本号,为后续不兼容升级提供可能。当一个接口有不同的实现,项目早期使用的一个实现类, 之后创建接口的新的实现类。区分不同的接口实现使用 version。特别是项目需要把早期接口的实现全部换位新的实现类,也需要使用 version。
可以用版本号从早期的接口实现过渡到新的接口实现,版本号不同的服务相互间不引用。
可以按照以下的步骤进行版本迁移:
- 在低压力时间段,先升级一半提供者为新版本
- 再将所有消费者升级为新版本
- 然后将剩下的一半提供者升级为新版本
例:以 zk-node-shop-userservice 为例。
4.5.1、复制 UserInfoServiceImpl.java
UserInfoServiceImpl2 中的地址信息都加入 2 的内容,用来区别原始的数据。
4.5.2、Dubbo 配置文件 userservice-provider.xml(服务提供者)
增加版本 version 标志
4.5.3、服务的 Dubbo 配置文件(服务消费者)
增加访问的 version=2.0
4.5.4、测试应用
- 先启动 zookeeper
- 启动 tomcat
- 访问 zk-node-shop-web
查看用户信息的地址是不同的内容