Dubbo启动过程(Spring方式)详解
一、使用Spring xml配置方式的启动过程
1. 解析XML,注册Bean
2. 监听Spring事件
3. 启动或关闭dubbo
二、详细过程
1. 解析XML,注册Bean
利用Spring提供的NamespaceHandler扩展机制,META-INF下放两个spring配置文件,
spring.schemas定义xsd文档位置,spring.handlers定义XML标签对应的Handler。
spring.schemas内容:
spring.handlers内容:
DubboNamespaceHandler继承NamespaceHandlerSupport(Spring类),并重写了init()方法。
在init()方法中,注册每个标签对应的解析类(DubboBeanDefinitionParser)。
NamespaceHandlerSupport类中以Map方式存储标签名及对应的解析类;
NamespaceHandlerSupport类中的parse(Element element, ParserContext parserContext)方法,是实际的解析入口,
解析时根据标签名获取对应的parser,然后再调用parser的parse方法(即DubboBeanDefinitionParser中的parse方法)。
在DubboBeanDefinitionParser的parse方法中,生成BeanDefinition对象,并使用ParserContext中的BeanDefinitionRegistry
注册到spring容器中,参考BeanDefinitionRegistry#registerBeanDefinition(String beanName, BeanDefinition beanDefinition)。
注意: dubbo的所有bean都是非懒加载的;
spring中,需要在parser的parse方法中注册bean,spring不负责注册parse方法返回的BeanDefinition。
另外,关于spring.handlers解析及DubboBeanDefinitionParser的init()方法调用,参考spring的DefaultNamespaceHandlerResolver。
2. 注册监听Spring事件
dubbo的jar包中,META-INF目录下有一个web-fragment.xml文件(web-fragment工作方式请自行百度)
其关键的内容如下,配置了一个context属性:contextInitializerClasses
DubboApplicationContextInitializer类源码如下:
可以看到,此处将DubboApplicationListener添加到Spring容器中(即AbstractApplicationContext中的listener列表)
DubboApplicationContextInitializer.initialize()方法在Spring中的执行过程:
web应用中,我们配置web.xml中的Spring启动监听器:
ContextLoaderListener中,contextInitialized()方法启动Spring容器。
ContextLoaderListener继承了ContextLoader,ContextLoader中customizeContext方法中,
读取contextInitializerClasses属性执行的class(多个class支持 ,; \t\n 四种分隔符),并调用其initialize()方法。
接下来看一下DubboApplicationListener内容:
Spring启动完成时,产生ContextRefreshEvent事件,并回调所有listener.
具体代码在:AbstractApplicationContext.finishRefresh()方法中:
publishEvent()中,再使用SimpleApplicationEventMulticaster.multicastEvent()方法回调所有监听器
的onApplicationEvent()方法。
至此,上述即为dubbo注册即监听Spring的过程。
另外,如果不是web应用是怎么做的呢?
Dubbo提供了SpringContainer来启动非web应用,依然是采用Spring注册监听机制
3. 启动dubbo
由DubboBootstrap.start()方法负责。
详细的启动过程下次给出。
本人水平有限,文中有不当之处欢迎评论中指出。
Dubbo启动过程(Spring方式)详解的更多相关文章
- Dubbo配置方式详解
Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案,是阿里巴巴 SOA 服务化治理方案的核心框架,每天为 2,000+ 个服务提供 3,000,000,000+ 次 ...
- [转载,感觉写的非常详细]DUBBO配置方式详解
[转载,感觉写的非常详细]DUBBO配置方式详解 原文链接:http://www.cnblogs.com/chanshuyi/p/5144288.html DUBBO 是一个分布式服务框架,致力于提供 ...
- Spring事务Transaction配置的五种注入方式详解
Spring事务Transaction配置的五种注入方式详解 前段时间对Spring的事务配置做了比较深入的研究,在此之间对Spring的事务配置虽说也配置过,但是一直没有一个清楚的认识.通过这次的学 ...
- 【转载】Spring AOP详解 、 JDK动态代理、CGLib动态代理
Spring AOP详解 . JDK动态代理.CGLib动态代理 原文地址:https://www.cnblogs.com/kukudelaomao/p/5897893.html AOP是Aspec ...
- spring事务详解(三)源码详解
系列目录 spring事务详解(一)初探事务 spring事务详解(二)简单样例 spring事务详解(三)源码详解 spring事务详解(四)测试验证 spring事务详解(五)总结提高 一.引子 ...
- Spring Bean 详解
Spring Bean 详解 Ioc实例化Bean的三种方式 1 创建Bean 1 使用无参构造函数 这也是我们常用的一种.在默认情况下,它会通过反射调⽤⽆参构造函数来创建对象.如果类中没有⽆参构造函 ...
- Spring RestTemplate详解
Spring RestTemplate详解 1.什么是REST? REST(RepresentationalState Transfer)是Roy Fielding 提出的一个描述互联系统架构风格 ...
- Dubbo支持的协议的详解
Dubbo支持dubbo.rmi.hessian.http.webservice.thrift.redis等多种协议,但是Dubbo官网是推荐我们使用Dubbo协议的.下面我们就针对Dubbo的每种协 ...
- 精通Dubbo——Dubbo支持的协议的详解
转: 精通Dubbo——Dubbo支持的协议的详解 2017年06月02日 22:26:57 孙_悟_空 阅读数:44500 Dubbo支持dubbo.rmi.hessian.http.webse ...
随机推荐
- [Unity移动端]Touch类
Touch类的信息只能在移动端(触摸屏)上能够获取,在编辑器上是不能获取到的.因此,为了方便测试,可以打包apk后在模拟器上跑: unity打包apk:https://www.jianshu.com/ ...
- SAP work process Memory allocate
Memory allocation sequence to dialog work processes in SAP What is the memory allocation sequence to ...
- mycat测试
mycat 目前最流行的分布式数据库中间插件 mycat能满足数据的大量存储,并能提高查询性能:同样应用程序与数据库解耦,程序只需知道中间件的地址,无需知道底层数据库,数据分布存储,提高读写性能,也可 ...
- sql server 查看对象最后修改时间
sql server 查看对象最后修改时间,根据最后修改时间排序 存储过程 SELECT * FROM sys.all_objects WHERE TYPE='P' ORDER BY modify_ ...
- web安全/渗透测试--1--web安全原则
web 安全: https://blog.csdn.net/wutianxu123/article/category/8037453/2 web安全原则 安全应该是系统开发之初就考虑的问题.换句话说 ...
- Crontab 删除N天前日志
linux是一个很能自动产生文件的系统,日志.邮件.备份等.虽然现在硬盘廉价,我们可以有很多硬盘空间供这些文件浪费,让系统定时清理一些不需要的文件很有一种爽快的事情.不用你去每天惦记着是否需要清理日志 ...
- jsfl 常用自定义方法
//创建文件夹 function creatFile(fileURl) { if (FLfile.createFolder(fileURl)) { //alert("创建成功 "+ ...
- 我要重新开始学习C++了!
C++实在是博大精深!之前总不想读厚厚的C++ Primer. 然而,现在的水平真的只是初学者!只是因为写的代码太简单,所以没有用到一些特性.可以说还是门外汉! 写笔记!
- 新装kafka与zookeeper配置
zookeeper配置 dataDir=/opt/kafka_2.11-2.0.0/data/zookeeper # 尽量不要放在tmp# the port at which the clients ...
- list<T>中的按特定顺序排序
前段时间有个任务,就是把参数要按特定顺序排序,就是要是在一张大的参数表中,只选取,2,5,12,9,13,10 这几个参数,并按上述顺序进行排序. 假设这个参数在一个类中.例如: 上述参数序列就存在P ...