专栏首页Java进阶架构师dubbo源码解析-详解directory

dubbo源码解析-详解directory

前言

由于明天还要加班(心疼自己一秒),之前答应过小伙伴每周更新一篇dubbo的源码解析的,鉴于上次讲到了集群容错的总体架构,这次主要讲讲第一个关键词directory,这个内容不多,比较适合这种时间比较紧的分享.后面还会陆续分享dubbo源码解析系列,但是不止于dubbo.

直入主题

首先来看一下directory接口的实现类,他主要有两个实现类,一个是StaticDirectory,一个是RegistryDirectory

其实这个也是道很好的面试题,他还是可以区分三种人

一种是停留在使用层面的,没看过源码的,因此他不会懂得这两个实现类

第二种是看过官网如下描述,因此认为directory的实现类都是动态变化的

Directory 代表多个 Invoker,可以把它看成 List ,但与 List 不同的是,它的值可能是动态变化的,比如注册中心推送变更

第三种则是有看过源码的,其实从StaticDirectory中的Static关键词来看,就知道,这个其实是不会动态变化的,从下图知道,他的Invoker是通过构造函数传入,StaticDirectory用得比较少,主要用在服务对多注册中心的引用

本文介绍的重点是RegistryDirectory

首先来看看他的继承结构

这个NotifyListener中的notify方法就是注册中心的回调,也就是它之所以能根据注册中心动态变化的根源所在.

下面放一个上篇中集群容错的整体架构中的一个图唤醒大家的对Directory记忆

从中可以看出,Directory获取invoker是从methodInvokerMap中获取的,从这个图也可以看出,这些主要都是读操作,那它的写操作是在什么时候写的呢?就是在回调方法notify的时候操作的

也就是注册中心有变化,则更新methodInvokerMap和urlInvokerMap的值(这个后面讲服务引用原理的时候会再提一下),这就是官网提到的它的值可能是动态变化的,比如注册中心推送变更的原因所在.

写在末尾

上一篇集群容错的整体架构篇幅较长,可能很多人没什么耐心看下去,所以本篇换成短小精干但是却不缺深度的分享.鉴于本人才疏学浅,不对的地方还望斧正,也欢迎关注我的简书,名称为肥朝

作者:肥朝 链接:https://www.jianshu.com/p/3d47873f8ad3

本文分享自微信公众号 - java进阶架构师(java_jiagoushi),作者:肥朝

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2018-08-07

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 一篇文章带你详解 HTTP 协议之报文首部及字段详解(中)

    先来回顾一下首部字段在报文的位置,HTTP 报文包含报文首部和报文主体,报文首部包含请求行(或状态行)和首部字段。 在报文众多的字段当中,HTTP 首部字段包含...

    java进阶架构师
  • Java虚拟机必学之四大知识要点

    作为一位 Java 程序员,在尽情享受 Java 虚拟机带来好处的同时,我们还应该去了解和思考“这些技术特性是如何实现的”,去了解最底层的原理。只有熟悉 JVM...

    java进阶架构师
  • 03:SpringBoot整合SpringDataJPA实现数据库的访问(二)

    首先回忆一下,前面我们创建studentRepo类继承JpaRepository<T,ID>接口,即可实现最基本的crud。如下:

    java进阶架构师
  • Dubbo 源码解析 —— Directory

    前言 由于明天还要加班(心疼自己一秒),之前答应过小伙伴每周更新一篇dubbo的源码解析的,鉴于上次讲到了集群容错的总体架构,这次主要讲讲第一个关键词 dire...

    芋道源码
  • 《闲扯Redis九》Redis五种数据类型之Set型

    Redis 中的 Set 是我们经常使用到的一种数据类型,根据使用方式的不同,可以应用到很多场景中。

    大道七哥
  • 机器人取代工人的末日剧情都是误导

    机器代替人类劳动的情况在一个世纪以前就已经发生了。不过人们因为缺乏知识,担心自身工作不保,或者满足于现有科技,经常对技术的进步和变化有消极抵抗的情绪。随着自动化...

    机器人网
  • Python中的正则表达式(五)

    分组的形式多种多样,以上简要介绍了几种最基本的,在上述内容基础上,可以进一步探讨其他分组形式。

    老齐
  • 画解算法 3-无重复字符的最长子串

    https://leetcode-cn.com/problems/longest-substring-without-repeating-characters/

    灵魂画师牧码
  • Go语言学习(四)| 数组、切片、集合

    array由 [n]<type> 定义,n为array的长度,<type>标示希望存储的内容的类型。例:

    Mervyn
  • vsan的主机故障及优化

    在上一篇文章中,我们已经知道了 VSAN 是如何处理容量设备和缓存设备磁盘故障的,那么,如果vsan主机发生故障,会如何呢?我们再来看看下面这幅图:

    孙杰

扫码关注云+社区

领取腾讯云代金券