RegistryProtocol.doRefer这里面进行的注册,将调用FailbackRegistry.registry进行真正的注册,实际跟zookeeper进行交互,调用的是ZookeeperRegistry的doRegistry方法。若是注册失败,会将url添加定定时任务中进行重试。html
AbstractRegistry.notify真正接收到zookeeper的通知。在那儿将notify接口添加到zookeeper的改变事件的呢?
在ZookeeperRegistry代码的doSubscribe方法中(与zookeeper进行交互的代码中),将订阅的接口发送给zookeeper,而且从zookeeper取得可用的服务列表。
ZookeeperRegistry代码:
zkClient.create(path, false);
//这个是zookeeper返回客户端订阅的服务
List<String> children = zkClient.addChildListener(path, zkListener);
if (children != null) {
urls.addAll(toUrlsWithEmpty(url, path, children));
}
在循环以外,将已经可用的列表进行通知。
notify(url, listener, urls);,调用了AbstractRegistry.notify
AbstractRegistry在收到通知后,将url进行存储,继续通知NotifyListener。
NotifyListener是在哪儿放入Registry的呢?
在RegistryProtocol订阅服务的时候,会调用RegistryDirectory.subscribe方法。RegistryDirectory这类自己就实现了NotifyListener接口,在调用FailbackRegistry的subscribe方法的时候,把本身当成一个参数传递给了AbstractRegistry对象。因此AbstractRegistry在收到通知后,继续通知的是RegistryDirectory。
RegistryDirectory这个类维护着从本地方法到远程方法的映射关系,远程参数到本地方法的调用关系等。
在注册过程当中的几个主要类
ZookeeperRegistry:负责与zookeeper进行交互
RegistryProtocol:从注册中心获取可用服务,或者将服务注册到zookeeper,而后提供服务或者提供调用代理。
RegistryDirectory:维护着全部可用的远程Invoker或者本地的Invoker。这个类实现了NotifyListner。
NotifyListener:负责RegistryDirectory和ZookeeperRegistry的通讯。
FailbackRegistry:继承自Registry,实现了失败重试机制。
回答一开始的问题
一、经过
ZookeeperRegistry和Zookeeper进行交互,相关的类还有ZookeeperClient,ZkclientZookeeperClient和org.I0Itec.zkclient.ZkClient类。经过这些类的方法,实现服务的注册和订阅及信息的传递。
二、主要是AbstractRegistry和RegistryDirectory这两个类。其中RegistryDirectory存储的可供客户端直接调用的Invoker,而AbstractRegistry这个类主要存储的是已经注册的服务接口,已经订阅的服务接口和已经收到通知的接口的URL,不能直接调用。
对这类话题感兴趣?欢迎发送邮件至
donlianli@126.com