Dubbo是阿里巴巴开源的一个由Java语言编写的分布式服务框架,核心部分包括以下三块:远程通信、集群容错、自动发现。其中Dubbo中的服务注册中心是基于ZooKeeper实现的,工作流程如下:
1、服务提供者
服务提供者在初始化启动的时候,会首先在ZooKeeper的/dubbo/com.foo.BarService/providers节点下创建一个子节点,并写入自己的URL地址。
2、服务消费者
服务消费者在启动的时候,读取并订阅ZooKeeper上/dubbo/com.foo.BarService/providers节点下的所有子节点,并解析处所有提供者的URL地址来作为该服务地址列表,然后开始发起正常调用。
服务消费者还会在ZooKeeper的/dubbo/com.foo.BarService/consumers节点下创建一个临时节点,并写入自己的URL地址。
3、监控中心
监控中心在启动的时候,会通过ZooKeeper的/dubbo/com.foo.BarService节点来获取所有提供者和消费者的URL地址,并注册Watcher来监听其子节点的变化。
注意:所有提供者在ZooKeeper上创建的节点都是临时节点。当提供者所在的服务器出现故障导致该提供者无法对外提供服务时,该临时节点就会自动从ZooKeeper上删除。