IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> 【Dubbo文件解析与暴露服务的过程~】 -> 正文阅读

[网络协议]【Dubbo文件解析与暴露服务的过程~】

Dubbo文件解析与暴露服务的过程:

文件解析

  1. 首先需要知道的是在服务启动的时候会先把dubbo相关的配置文件进行解析,这个解析过程之初会由 dubbo命名空间处理器(DubboNamespaceHandler)在它的初始化方法init()中创建很多dubbo标签解析器对象(DubboBeanDefinitionParser ),
  2. 该解析器中专门有一个解析方法parse() 执行解析操作;parse()会挨个的解析配置文件中的dubbo标签,将每个标签中的信息都解析出来封装到一个对应的Config里面;每一个dubbo标签都有一个对应的XXXConfig,比如RegistryConfig等;但是Service标签对应的是ServiceBeanServiceBean中就涉及到了dubbo暴露服务的过程。

暴露服务

  1. ServiceBean中各种属性设置完成之后就会调用一个**afterPropertiesSet()**方法,该方法会将我们配置的属性信息都封装在ServiceBean中,

  2. 在afterPropertiesSet()执行完IOC容器创建刷新完成后就实现并调用ApplicationListener接口的onApplicationEvent() 方法,在该方法中会调用一个export() 方法, 也就是暴露的意思,

  3. 这个export()会进入到ServiceConfig中的export()方法中;里面会调用本类(ServiceConfig)中的 doexport() 方法(执行暴露);doexport()中又调用doexpotrUrls() (执行暴露Url ); 这个方法中有 doExportUrlsFor1Protocol() 方法,(暴露协议的URL

  4. doExportUrlsFor1Protocol()中先通过协议工厂(ProxyFactory)对象的 getInvoker() 方法得到一个Invoker,(具体是:获取接口对象的invoker,将接口实现和URL等等一些东西通过代理工厂对象进行包装组合成了Invoker)

  5. 对上面获得的Invoker再次包装,然后又通过(Protocol)协议的对象调用export()方法,将这个包装后的Invoker暴露;protpcol.export(invoker)

  6. 上述protpcol.export(invoker)会返回一个Exporter对象(暴露器);

  7. 第六步通过Protocol调用export方法时会先去RegistryProcol(注册器协议)中的export()中进行Localexport() (本地暴露),但是 Localexport()中还是调用protpcol.export()也就是export()包裹export()。

  8. RegistryProcol中的暴露器export()除了本地暴露外还会注册到注册中心;ProviderConsumerRegTable.registerProvider()把URL地址跟服务的执行器(Invoker)保存在注册表中,执行器中保存着真正的服务,这样的话当20880端口启动时就会根据URL地址在注册表中找到对应的执行器(Invoker)就能进行调用服务了

  9. 第六步中除了调用注册中心的暴露器还会调用Dubbo的暴露器;在Dubbo的export()中会进行开启服务;也就是执行openService() openServer做的就是启动Netty服务器,监听20880端口;

  10. 至此服务暴露完成~

大概的图:
在这里插入图片描述

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2022-05-25 11:44:25  更:2022-05-25 11:44:51 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/19 16:01:51-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码