初步了解 Dubbo 初始化,加載


通過分析 dubbo demo 的spring xml 配置,初步了解 dubbo的類加載和回顧spring的加載信息

Demo

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	   xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
	   xsi:schemaLocation="
		http://www.springframework.org/schema/beans 
		http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
		http://code.alibabatech.com/schema/dubbo 
		http://code.alibabatech.com/schema/dubbo/dubbo.xsd">

	<!-- 和本地bean一樣實現服務 -->
	<xsi:bean id="demoService" class="com.alibaba.dubbo.demo.provider.DemoServiceImpl"/>

	<!-- 提供方應用信息,用於計算依賴關系 -->
	<dubbo:application name="demo-provider"/>

	<!-- 使用multicast廣播注冊中心暴露服務地址 -->
	<dubbo:registry address="multicast://224.5.6.7:1234"/>

	<!-- 用dubbo協議在20880端口暴露服務 -->
	<dubbo:protocol name="dubbo" port="20880"/>

	<!-- 聲明需要暴露的服務接口 -->
	<dubbo:service interface="com.alibaba.dubbo.demo.DemoService" ref="demoService"/>

</beans>

說明

XML Schema命名空間作用:  
1、避免命名沖突,像Java中的package一樣  
  
2、將不同作用的標簽分門別類(像Spring中的tx命名空間針對事務類的標簽,context命名空間針對組件的標
簽,dubbo 則是dubbo服務的命名空間)  

代碼解釋

1、xmlns="http://www.springframework.org/schema/beans"  
聲明xml文件默認的命名空間,表示未使用其他命名空間的所有標簽的默認命名空間。  
  
2、xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
聲明XML Schema 實例,聲明后就可以使用 schemaLocation 屬性  
  
3、xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
聲明前綴為dubbo的命名空間,后面的URL用於標示命名空間的地址不會被解析器用於查找信息。其惟一的作用
是賦予命名空間一個惟一的名稱。當命名空間被定義在元素的開始標簽中時,所有帶有相同前綴的子元素都會與
同一個命名空間相關聯。  
  
4、xsi:schemaLocation="  
http://www.springframework.org/schema/beans 
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd"  
這個從命名可以看出個大概,指定Schema的位置這個屬性必須結合命名空間使用。這個屬性有兩個值,第一個
值表示需要使用的命名空間。第二個值表示供命名空間使用的 XML schema 的位置。  

需要什么樣的標簽的時候,就引入什么樣的命名空間和Schema。

spring 加載dubbo 的入口

在dubbo-{version}.jar 中 META-INF/spring.handlers 中可以看到
http\://code.alibabatech.com/schema/dubbo=com.alibaba.dubbo.config.spring.schema.DubboNamespaceHandler

DubboNamespaceHandler 即dubbo 通過spring的handler處理類

DubboNamespaceHandler代碼

	public class DubboNamespaceHandler extends NamespaceHandlerSupport {
    static {
        Version.checkDuplicate(DubboNamespaceHandler.class);
    }

    public void init() {
        registerBeanDefinitionParser("application", new DubboBeanDefinitionParser(ApplicationConfig.class, true));
        registerBeanDefinitionParser("module", new DubboBeanDefinitionParser(ModuleConfig.class, true));
        registerBeanDefinitionParser("registry", new DubboBeanDefinitionParser(RegistryConfig.class, true));
        registerBeanDefinitionParser("monitor", new DubboBeanDefinitionParser(MonitorConfig.class, true));
        registerBeanDefinitionParser("provider", new DubboBeanDefinitionParser(ProviderConfig.class, true));
        registerBeanDefinitionParser("consumer", new DubboBeanDefinitionParser(ConsumerConfig.class, true));
        registerBeanDefinitionParser("protocol", new DubboBeanDefinitionParser(ProtocolConfig.class, true));
        registerBeanDefinitionParser("service", new DubboBeanDefinitionParser(ServiceBean.class, true));
        registerBeanDefinitionParser("reference", new DubboBeanDefinitionParser(ReferenceBean.class, false));
        registerBeanDefinitionParser("annotation", new DubboBeanDefinitionParser(AnnotationBean.class, true));
    }
}

上述xml 解析完后,可以大概的看做是如下spring bean 的加載

<bean id="demo-provider" class="com.alibaba.dubbo.config.ApplicationConfig"/>  

<bean id="registryConfig" class="com.alibaba.dubbo.config.RegistryConfig">  
    <property name="address" value="multicast://224.5.6.7:1234"/>   
</bean>  

<bean id="dubbo" class="com.alibaba.dubbo.config.ProtocolConfig">  
    <property name="port" value="20880"/>  
</bean>  

<bean id="com.alibaba.dubbo.demo.DemoService" class="com.alibaba.dubbo.config.spring.ServiceBean">  
    <property name="interface" value="com.alibaba.dubbo.demo.DemoService"/>  
    <property name="ref" ref="demoService"/>  
</bean>  

<bean id="demoService" class="com.alibaba.dubbo.demo.provider.DemoServiceImpl" />


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM