Dubbo ExtensionLoader工作流程

2024-06-01 15:08

本文主要是介绍Dubbo ExtensionLoader工作流程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ExtensionLoader是Dubbo扩展机制的核心类,其中实现了配置的加载、扩展类的缓存、自适应扩展对象的生成等。

ExtensionLoader的逻辑入口可分为getExtension、getAdaptiveExtension、getActivateExtension,分别代表着获取普通扩展类、获取自适应扩展类、获取自动激活扩展类。

getExtension

getExtension(String name)是整个扩展加载器中最核心的方法,实现了一个完整的普通扩展类加载过程,加载过程中的每一步都会先检查缓存中是否已经存在所需的内容,存在则直接返回,不存在则调用createExtension重新加载。每次只会根据名称返回一个扩展点实现类。

初始化过程可分为4步:

1、读取SPI对应路径下的配置文件,并根据配置加载所有扩展类并缓存(不初始化)。

2、根据传入的名称初始化对应的扩展类。

3、尝试找到符合条件的包装类,如果有包含与扩展点类型相同的构造函数,为其注入刚初始化的扩展类。

4、返回对应的扩展点实现类实例。

getAdaptiveExtension

getAdaptiveExtension与getExtension一样,加载过程中的每一步都会先检查缓存中是否已经存在所需的内容,存在则直接返回,不存在则调用createAdaptiveExtension重新加载,初始化过程如下:

1、和getExtension一样先加载配置文件。

2、生成自适应类的代码字符串。

3、获取类加载器和编译器,并用编译器编译刚刚生成的代码。

4、返回对应的自适应类实例。

getActivateExtension

getActivateExtension的主要流程如下:

1、检查缓存,如果缓存中没有,则初始化所有扩展类实现的集合。

2、遍历整个@Activate注解集合,根据传入URL匹配条件(匹配group、value等),得到所有符合激活条件的扩展类实现,然后再根据注解中配置的before、after、order等参数进行激活排序。

3、返回所有自动激活类集合。

这篇关于Dubbo ExtensionLoader工作流程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1021341

相关文章

将Java项目提交到云服务器的流程步骤

《将Java项目提交到云服务器的流程步骤》所谓将项目提交到云服务器即将你的项目打成一个jar包然后提交到云服务器即可,因此我们需要准备服务器环境为:Linux+JDK+MariDB(MySQL)+Gi... 目录1. 安装 jdk1.1 查看 jdk 版本1.2 下载 jdk2. 安装 mariadb(my

Go 语言中的select语句详解及工作原理

《Go语言中的select语句详解及工作原理》在Go语言中,select语句是用于处理多个通道(channel)操作的一种控制结构,它类似于switch语句,本文给大家介绍Go语言中的select语... 目录Go 语言中的 select 是做什么的基本功能语法工作原理示例示例 1:监听多个通道示例 2:带

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

Spring AI ectorStore的使用流程

《SpringAIectorStore的使用流程》SpringAI中的VectorStore是一种用于存储和检索高维向量数据的数据库或存储解决方案,它在AI应用中发挥着至关重要的作用,本文给大家介... 目录一、VectorStore的基本概念二、VectorStore的核心接口三、VectorStore的

python之流程控制语句match-case详解

《python之流程控制语句match-case详解》:本文主要介绍python之流程控制语句match-case使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录match-case 语法详解与实战一、基础值匹配(类似 switch-case)二、数据结构解构匹

kotlin中的模块化结构组件及工作原理

《kotlin中的模块化结构组件及工作原理》本文介绍了Kotlin中模块化结构组件,包括ViewModel、LiveData、Room和Navigation的工作原理和基础使用,本文通过实例代码给大家... 目录ViewModel 工作原理LiveData 工作原理Room 工作原理Navigation 工

在VSCode中本地运行DeepSeek的流程步骤

《在VSCode中本地运行DeepSeek的流程步骤》本文详细介绍了如何在本地VSCode中安装和配置Ollama和CodeGPT,以使用DeepSeek进行AI编码辅助,无需依赖云服务,需要的朋友可... 目录步骤 1:在 VSCode 中安装 Ollama 和 CodeGPT安装Ollama下载Olla

linux环境openssl、openssh升级流程

《linux环境openssl、openssh升级流程》该文章详细介绍了在Ubuntu22.04系统上升级OpenSSL和OpenSSH的方法,首先,升级OpenSSL的步骤包括下载最新版本、安装编译... 目录一.升级openssl1.官网下载最新版openssl2.安装编译环境3.下载后解压安装4.备份

C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)

《C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)》本文主要介绍了C#集成DeepSeek模型实现AI私有化的方法,包括搭建基础环境,如安装Ollama和下载DeepS... 目录前言搭建基础环境1、安装 Ollama2、下载 DeepSeek R1 模型客户端 ChatBo

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块