zoukankan      html  css  js  c++  java
  • 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支持 ,; 四种分隔符),并调用其initialize()方法。

      接下来看一下DubboApplicationListener内容:

      

      Spring启动完成时,产生ContextRefreshEvent事件,并回调所有listener.

      具体代码在:AbstractApplicationContext.finishRefresh()方法中:

      

       publishEvent()中,再使用SimpleApplicationEventMulticaster.multicastEvent()方法回调所有监听器

      的onApplicationEvent()方法。

      

      

      至此,上述即为dubbo注册即监听Spring的过程。

      另外,如果不是web应用是怎么做的呢?

        Dubbo提供了SpringContainer来启动非web应用,依然是采用Spring注册监听机制

         

    3. 启动dubbo

      由DubboBootstrap.start()方法负责。

      

      详细的启动过程下次给出。

    本人水平有限,文中有不当之处欢迎评论中指出。

  • 相关阅读:
    Oracle 导入导出报错的简单处理
    Windows 下面 winrar 压缩简单记录
    zip 与 unzip的简单使用
    [知乎]山东:一枚神奇独一的“三棱锥”
    【喷嚏图卦】 委内瑞拉崩溃的背后:渐行渐近的石油危机
    [互联网]2018年互联网套路简史
    [wiki]陶德曼调停
    [阮一峰]找回密码的功能设计
    sap 最新财报以及云业务转型情况
    debian 7 安装 rz sz lrzsz
  • 原文地址:https://www.cnblogs.com/selfchange/p/9905234.html
Copyright © 2011-2022 走看看