Dubbo目前支持4种注册中心,(multicast,zookeeper,redis,simple) 推荐使用Zookeeper注册中心。
一、Multicast注册中心
不需要启动任何中心节点,只要广播地址一样,就可以互相发现。组播受网络结构限制,只适合小规模应用或开发阶段使用。
组播地址段: 224.0.0.0 - 239.255.255.255
相关概念解析:
提供方启动时广播自己的地址。
消费方启动时广播订阅请求。
提供方收到订阅请求时,单播自己的地址给订阅者,如果设置了unicast=false,则广播给订阅者。
消费方收到提供方地址时,连接该地址进行RPC调用。
配置multicast 注册中心
Or:
为了减少广播量,Dubbo缺省使用单播发送提供者地址信息给消费者,如果一个机器上同时启了多个消费者进程,消费者需声明unicast=false,否则只会有一个消费者能收到消息:
unicast配置方法:
Or:
二、Zookeeper注册中心
建议使用dubbo-2.3.3以上版本的zookeeper注册中心客户端。
Zookeeper说明
Zookeeper是Apacahe Hadoop的子项目,是一个树型的目录服务,
流程说明:
Provider服务提供者启动时
向/dubbo/com.foo.BarService/providers目录下写入自己的URL地址。
Consumer服务消费者启动时
订阅/dubbo/com.foo.BarService/providers目录下的提供者URL地址。
并向/dubbo/com.foo.BarService/consumers目录下写入自己的URL地址。
监控中心启动时
订阅/dubbo/com.foo.BarService目录下的所有提供者和消费者URL地址。
支持以下功能:
当提供者出现断电等异常停机时,注册中心能自动删除提供者信息。
当注册中心重启时,能自动恢复注册数据,以及订阅请求。
当会话过期时,能自动恢复注册数据,以及订阅请求。
当设置时,记录失败注册和订阅请求,后台定时重试。
可通过设置zookeeper登录信息。
可通过设置zookeeper的根节点,不设置将使用无根树。
支持*号通配符,可订阅服务的所有分组和所有版本的提供者。
在provider和consumer中增加zookeeper客户端jar包依赖:
org.apache.z