• RPC中实现提供者信息变化后通知消费者


    目录

    Zookeeper的Watcher

    消费者端的事件监听(观察者模式)


    Zookeeper的Watcher

    使用Java可以链接Zookeeper并且进行节点的增删改查以及监听,目前有三套API可以使用。

    这里用的是CuratorFramework。 这个client就是一个CuratorFramework的实现。

     zk收到节点变更后就会执行 process方法。这样在process方法中执行消费者本地的缓存修改即可。为了解耦,采用了事件监听器在process中需要注意zk节点的消息通知是一次性的,所以在执行完process之后 需要重新监听该节点。

    1. public void watchNodeDataChange(String newServerNodePath) {
    2. zkClient.watchNodeData(newServerNodePath, new Watcher() {
    3. @Override
    4. public void process(WatchedEvent watchedEvent) {
    5. String path = watchedEvent.getPath();
    6. System.out.println("[watchNodeDataChange] 监听到zk节点下的" + path + "节点数据发生变更");
    7. String nodeData = zkClient.getNodeData(path);
    8. // 把 url字符串 转化为一个 providerNodeInfo
    9. ProviderNodeInfo providerNodeInfo = URL.buildURLFromUrlStr(nodeData);
    10. IRpcEvent iRpcEvent = new IRpcNodeChangeEvent(providerNodeInfo);
    11. IRpcListenerLoader.sendEvent(iRpcEvent);
    12. //因为zk节点的消息通知其实是只具有一次性的功效,所以
    13. // 可能会出现第一次修改节点之后发送一次通知,
    14. // 之后再次修改节点不再会发送节点变更通知操作。
    15. ZookeeperRegister.this.watchNodeDataChange(newServerNodePath);
    16. }
    17. });
    18. }

    消费者端的事件监听(观察者模式)

    事件机制三大要素是事件源,事件监听器和事件对象,事件监听器注册到事件源上,如果事件源上发生了变化就会产生某些事件,会交给相应的事件监听器去处理。

    1. public static void sendEvent(IRpcEvent iRpcEvent) {
    2. if (CommonUtils.isEmptyList(iRpcListenerList)) {
    3. //iRpcListenerList 里面有多种事件监听器
    4. return;
    5. }
    6. for (IRpcListener iRpcListener : iRpcListenerList) {
    7. //通过 事件监听器的参数类型确定该事件应该倍哪一个事件监听器处理
    8. Class type = getInterfaceT(iRpcListener);
    9. if (type.equals(iRpcEvent.getClass())) {
    10. // 使用线程池进行异步事件处理
    11. eventThreadPool.execute(() -> {
    12. try {
    13. iRpcListener.callBack(iRpcEvent.getData());
    14. } catch (Exception e) {
    15. e.printStackTrace();
    16. }
    17. });
    18. }
    19. }
    20. }

     

  • 相关阅读:
    2.3.1 交换机的链路聚合技术
    CentOS7 —— yum安装mysql
    子代选择器 并集选择器 伪类选择器
    在Android studio高版本上使用低版本的Github项目库报错未能解析:Landroid/support/v4/app/FrageActivity;
    基于Django+MySQL的智慧校园系统
    爱上开源之golang入门至实战第四章函数(Func)(七)
    java中的static关键字几个注意点
    STM32 4位数码管和74HC595
    React源码解读之更新的创建
    14.4 Socket 双向数据通信
  • 原文地址:https://blog.csdn.net/weixin_40757930/article/details/125897576