4.1 配置原则

在服务提供者配置访问参数。因为服务提供者更了解服务的各种参数。

4.2 关闭检查

dubbo 缺省会在启动时检查依赖的服务是否可用,不可用时会抛出异常,阻止 Spring 初始化完成,以便上线时,能及早发现问题,默认 check=true。通过 check=”false”关闭检查,比如,测试时,有些服务不关心,或者出现了循环依赖,必须有一方先启动。

例 1:关闭某个服务的启动时检查
**

例 2:关闭注册中心启动时检查
**

默认启动服务时检查注册中心存在并已运行。注册中心不启动会报错。

4.3 重试次数

消费者访问提供者,如果访问失败,则切换重试访问其它服务器,但重试会带来更长延迟。访问时间变长,用户的体验较差。多次重新访问服务器有可能访问成功。可通过 retries=“2” 来设置重试次数(不含第一次)。

4. Dubbo的配置 - 图1

4.4 超时时间

由于网络或服务端不可靠,会导致调用出现一种不确定的中间状态(超时)。为了避免超时导致客户端资源(线程)挂起耗尽,必须设置超时时间。

timeout: 调用远程服务超时时间(毫秒)

4.4.1 Dubbo 服务消费者

4.4.2 Dubbo 服务提供者

4.5 版本号

每个接口都应定义版本号,为后续不兼容升级提供可能。当一个接口有不同的实现,项目早期使用的一个实现类, 之后创建接口的新的实现类。区分不同的接口实现使用 version。特别是项目需要把早期接口的实现全部换位新的实现类,也需要使用 version。

可以用版本号从早期的接口实现过渡到新的接口实现,版本号不同的服务相互间不引用。

可以按照以下的步骤进行版本迁移:
**

  1. 在低压力时间段,先升级一半提供者为新版本
  2. 再将所有消费者升级为新版本
  3. 然后将剩下的一半提供者升级为新版本

例:以 zk-node-shop-userservice 为例。
**

4.5.1 复制 UserInfoServiceImpl.java

4. Dubbo的配置 - 图2

UserInfoServiceImpl2 中的地址信息都加入 2 的内容,用来区别原始的数据。

4.5.2 Dubbo 配置文件 userservice-provider.xml(服务提供者)

增加版本 version 标志

4. Dubbo的配置 - 图3

4.5.3 服务的 Dubbo 配置文件(服务消费者)

增加访问的 version=2.0

4. Dubbo的配置 - 图4

4.5.4 测试应用

  1. 先启动 zookeeper
  2. 启动 tomcat
  3. 访问 zk-node-shop-web

查看用户信息的地址是不同的内容