Dubbo服务暴露机制

前言

在进行服务暴露机制的分析之前,必须谈谈什么是URL,在Dubbo服务暴露过程中URL是无处不在的,贯穿了整个过程。

一般情况下,URL指的是统一资源定位符,标准格式如下:

protocol://host:port/path?key1=value1&key2=value2

Dubbo就是用这种URL的方式来作为约定的参数类型,服务之间也是用URL来进行交互。

Dubbo用URL作为配置总线,贯穿整个源码体系。

URL的具体参数如下:

  • protocol:dubbo中的各种协议,如:dubbo、http、thrift
  • host/port:主机/端口号
  • path:接口名称
  • parameters:参数键值对

服务暴露流程

大体流程分为三个步骤:

  • 检测配置,有些配置为空值会有默认值自动填充并自动组装为URL
  • 暴露服务,包括暴露到本地和远程的服务
  • 注册为服务到服务注册中心

源码解析

先来到ServiceBean

可以看到这个类实现了ApplicationListener<ContextRefreshedEvent>,这样就会在Spring IOC容器刷新之后调用onApplicationEvent方法,这个方法中做的就是服务暴露

if判断条件中,我们可以看到如果配置中没有设置延迟暴露、并且没有暴露过、并且支持暴露的情况下就会执行this.export(),最终会调用父类ServiceConfig中的export方法。

上述方法中主要就是进行配置检查,然后进入this.doExport()进行服务暴露,这个方法前面的部分都是一些配置检查,重点放在最后的this.doExportUrls()

从上述源码中可以看到Dubbo是支持多注册中心的,并且支持多种协议,一个服务如果有多个协议那么都需要暴露。this.loadRegistries()是根据配置组装成注册中心相关的URL,如下:

registry://127.0.0.1:2181/com.alibaba.dubbo.registry.RegistryService?application=user-service-provider-one&dubbo=2.6.2&pid=29056&registry=zookeeper&timestamp=1632309180780

接下来进入this.doExportUrlsFor1Protocol()

构建完成之后的URL如下图所示:

使用的是dubbo协议,接下来要做的就是根据URL来进行服务暴露

本地暴露

进入exportLocal()看一下,这个方法做的事就是进行本地暴露,使用的是injvm协议,这个方法中对URL进行修改,将协议改为injvm

此处的protocol.export()是标注了@Adaptive注解的,设计自适应拓展,调用该方法之后会生成代理类,代理类通过URL中的参数得知所使用的协议,然后通过Dubbo SPI机制实现拓展,选择对应的实现类进行export()方法,此处的方法会选择InjvmProtocol中的export()进行暴露。

经过转化后得到的export如下所示:

如图所示,具体实现类被层层包装。

为什么要封装成invoker呢?

封装成invoker是为了屏蔽调用的细节,统一暴露出一个可执行体,使得调用者调用时变得便捷简易。

为什么要使用本地暴露呢?

因为可能存在本地不同服务之间相互调用的情况,因此本地暴露后,内部可以直接进行调用,而省去了不必要的网络通信。

此处引用一下博主敖丙的文章中的本地暴露流程图:


远程暴露

此时本地暴露已经完成了,现在开始远程暴露。

流程与本地暴露相似,都需要先封装为invoker然后再进一步生成exporter,以下是registryURL.addParameterAndEncoded()方法将URL进行拼接后的结果:

可以看到先是走registry协议,然后参数中有一个export=dubbo://,此时会走dubbo协议,所以我们得知SPI会先通过registry协议找到RegistryPotocol然后执行export(),然后再执行DubboPotocol中的export()

现在我们进入RegistryPotocol中的export()方法。

上述操作主要是讲export转化为exporter,获取注册中心的相关配置,如果需要注册则向注册中心进行注册,并且在ProviderConsumerRegTable中记录服务提供者信息,进入源码中,我们发现实质就是往一个ConcurrentHashMap中塞入invoker,key是服务接口全类名,value是一个set,set中存储包装过的invoker。

然后进入 doLocalExport 方法内部

箭头指向的方法最终会调用DubboProtocol中的export()

需要创建server

上述代码中,主要就是根据URL创建出key,然后将key和invoker存入exporterMap中关联起来,如果是初次服务暴露则需要创建监听服务器,默认是NettyServer,并且初始化各种Handler,比如心跳检测,解码等。

至此服务暴露流程结束。

此处引用博主敖丙的文章中的本地暴露流程图:

以上。

整理不易,如果对你有帮助留个三连吧!

如果不足或错误欢迎评论指正。

Dubbo暴露服务过程相关推荐

  1. Dubbo暴露服务源码解析

    Dubbo服务提供方的JavaBean对应的就是ServiceBean.ServiceBean除了继承dubbo自己的配置抽象类以外,还实现了一系列的spring接口用来参与到spring容器的启动以 ...

  2. Dubbo中暴露服务的过程解析

    原文链接 dubbo暴露服务有两种情况,一种是设置了延迟暴露(比如delay="5000"),另外一种是没有设置延迟暴露或者延迟设置为-1(delay="-1" ...

  3. dubbo源码学习(四):暴露服务的过程

    dubbo采用的nio异步的通信,通信协议默认为 netty,当然也可以选择 mina,grizzy.在服务端(provider)在启动时主要是开启netty监听,在zookeeper上注册服务节点, ...

  4. Maven多模块,Dubbo分布式服务框架,SpringMVC,前后端分离项目,基础搭建,搭建过程出现的问题...

    现互联网公司后端架构常用到Spring+SpringMVC+MyBatis,通过Maven来构建.通过学习,我已经掌握了基本的搭建过程,写下基础文章为而后的深入学习奠定基础. 首先说一下这篇文章的主要 ...

  5. Maven多模块,Dubbo分布式服务框架,SpringMVC,前后端分离项目,基础搭建,搭建过程出...

    一.Maven多模块项目的创建 我们需要建立一个多模块的maven项目,其目录结构为 其中student-api用于暴露接口:student-service用语处理业务逻辑及调用数据访问对象,返回相应 ...

  6. 阿里面试官:你知道Dubbo的服务暴露机制么?

    点赞再看,养成习惯,微信搜一搜[三太子敖丙]关注这个喜欢写情怀的程序员. 本文 GitHub https://github.com/JavaFamily 已收录,有一线大厂面试完整考点.资料以及我的系 ...

  7. dubbo源码学习三—暴露服务exporter、invoker

    前面我们知道通过自定义标签,我们可以定位到相关标签的解析,同时梳理出三个重要的bean:ServiceBean.ReferenceBean.ConfigCenterBean. 通过Servicebea ...

  8. Dubbo使用multicast广播注册中心暴露服务地址时启动报错empty notify

    2019独角兽企业重金招聘Python工程师标准>>> 开发机上Dubbo使用multicast广播注册中心暴露服务地址 <dubbo:registry protocol=&q ...

  9. 7开启uasp协议_Dubbo-go 源码笔记(一)Server 端开启服务过程

    导读:随着微服务架构的流行,许多高性能 rpc 框架应运而生,由阿里开源的 dubbo 框架 go 语言版本的 dubbo-go 也成为了众多开发者不错的选择.本文将介绍 dubbo-go 框架的基本 ...

最新文章

  1. Spring Cloud Alibaba教程:使用Nacos作为服务注册中心
  2. AE实现不同图层的合并C#代码
  3. Android开发出现Warning:Gradle version 2.10 is required. Current version is 2.8
  4. iKcamp出品|全网最新|微信小程序|基于最新版1.0开发者工具之初中级培训教程分享...
  5. 平衡树 - FHQ 学习笔记
  6. LeetCode 887. Super Egg Drop
  7. html点导航栏换图片,jQuery点击导航栏选中更换样式的实现代码
  8. JavaScript语言精粹:对象——读书笔记
  9. [Yii Framework] yii中如何不加载layout
  10. 7.PL_SQL——在PL_SQL程序中内嵌查询语句、DML语句、事物处理语句和游标属性
  11. Microsoft Office SharePoint Server 2007 Trial Version已经可以下载了
  12. JMX详解及JConsole使用
  13. 威漫哨兵机器人_曾经秒杀X战警的哨兵机器人,在漫威漫画原著里更让人头疼!...
  14. 最常用的计算机色彩表示方法——RGB模式与CMYK模式
  15. 期货手续费怎么计算?
  16. 运用windows shell修复Wannacry漏洞
  17. python解一元二次方程复数_一元二次方程求解(包括复数各种情况)
  18. [Excel]rank函数实现自动排序
  19. DllNotFoundException
  20. 月嫂公司如何把一次性的生意,变成源源不断的生钱机器

热门文章

  1. mysql 目录武沛齐_MySQL数据表中的数据操作
  2. java 金_java
  3. 学完python_学完Python都可以做什么
  4. Leetcode 25 K个一组翻转链表 (每日一题 20210719)
  5. 信息熵和交叉熵的细节理解
  6. 隐式马可夫模型(hidden markov model,HMM)
  7. python实现自动发送微博,当自己写博客时同步上去。
  8. php连接redis报错,PHP使用phpredis链接redis错误
  9. 5类6类7类网线对比_未来值得投资的6类苗木,5年内市场前景应该都不错!
  10. JAVA API实现HDFS操作(二)操作函数