Dubbo.xml配置源-Dubbo.xsd分析
我们使用Dubbo时,一般都会使用xml配置基本信息,如项目名称(application)、注册中心(register)、协议(protocal)、服务(service),如下所示:
1
2
3
4
5
6
7
|
< dubbo:application name = "demo-provider" owner = "programmer" organization = "dubbox" /> < dubbo:protocol name = "dubbo" serialization = "kryo" optimizer = "com.alibaba.dubbo.demo.SerializationOptimizerImpl" /> < dubbo:service interface = "com.alibaba.dubbo.demo.bid.BidService" ref = "bidService" protocol = "dubbo" /> |
可是大家这些xml节点都是从哪里来的,为什么dubbo启动时可以识别,为什么输入有提示,下面首先为大家介绍一下xml节点从哪里来,为什么可以自动提示?下一篇再介绍怎样处理xml内容。
一、从哪里来?
首先看xml的beans根目录的URL:http://code.alibabatech.com/schema/dubbo
1
2
3
4
5
6
7
8
9
10
|
<? xml version = "1.0" encoding = "UTF-8" ?> xsi:schemaLocation=" |
为什么引入这个dubbo的url,在xml文件中就可以自动提示相应的节点信息,我们首先看dubbo源码中的和两个文件:
1、repository\com\alibaba\dubbo\2.5.3\dubbo-2.5.3\META-INF\spring.handlers
图中的代码说明了url对应的处理类
2、repository\com\alibaba\dubbo\2.5.3\dubbo-2.5.3\META-INF\spring.schemas
图中的代码说明了url对应的xsd文件
二、Dubbo.xsd的组成
第一步中解释了xml元素的来源,下一步通过分析dubbo.xsd文件解释xml元素、属性及自动提示。
dubbo.xsd主要包含以下4个类型的元素:
1、xsd:import:引入其它标签库,dubbo.xsd中还需要其它的xsd,处理方式和dubbo.xsd相同
1
2
3
|
|
2、xsd:annotation:xsd文件描述
1
2
3
|
< xsd:annotation > < xsd:documentation > <![CDATA[ Namespace support for the dubbo services provided by dubbo framework. ]]> </ xsd:documentation > </ xsd:annotation > |
3、xsd:complexType name="abstractMethodType:abstract开头的complextType:作为其它complexType类型的基类,提取共同的属性配置
这个抽象complexType只列出了前面两个参数:timeout、retries
1
2
3
4
5
6
7
8
9
10
11
|
< xsd:complexType name = "abstractMethodType" > < xsd:attribute name = "timeout" type = "xsd:string" use = "optional" default = "0" > < xsd:annotation > < xsd:documentation > <![CDATA[ The method invoke timeout. ]]> </ xsd:documentation > </ xsd:annotation > </ xsd:attribute > < xsd:attribute name = "retries" type = "xsd:string" use = "optional" > < xsd:annotation > < xsd:documentation > <![CDATA[ The method retry times. ]]> </ xsd:documentation > </ xsd:annotation > </ xsd:attribute > |
4、xsd:element name="service" type="serviceType:某个节点的配置,这里以service节点为例,type属性指向了具体的类型
type属性值说明具体的元素时serviceType
1
2
3
4
5
|
< xsd:element name = "service" type = "serviceType" > < xsd:annotation > < xsd:documentation > <![CDATA[ Export service config ]]> </ xsd:documentation > </ xsd:annotation > </ xsd:element > |
5、xsd:complexType name="serviceType":某个节点的具体属性,第4步中type属性指向的节点,其中base属性指向集成的complexType
具体的complexType(部分),包括子元素method、parameter,基类元素abstractServiceType
1
2
3
4
5
6
7
8
|
< xsd:complexType name = "serviceType" > < xsd:complexContent > < xsd:extension base = "abstractServiceType" > < xsd:choice minOccurs = "0" maxOccurs = "unbounded" > < xsd:element ref = "method" minOccurs = "0" maxOccurs = "unbounded" /> < xsd:element ref = "parameter" minOccurs = "0" maxOccurs = "unbounded" /> < xsd:element ref = "beans:property" minOccurs = "0" maxOccurs = "unbounded" /> </ xsd:choice > |
三、dubbo.xml配置文件和dubbo.xsd的关系
1、示例一:protocol
1
2
|
< dubbo:protocol name = "dubbo" port = "-1" dispatcher = "all" threadpool = "fixed" threads = "100" /> |
对应的dubbo.xsd节点
2、示例二
1
2
3
|
< dubbo:service interface = "org.gossip.dub.facade.ISeckillService" ref = "seckillService" retries = "0" > < dubbo:method name = "a1" ></ dubbo:method > </ dubbo:service > |
Dubbo.xml配置源-Dubbo.xsd分析的更多相关文章
- 【Dubbo源码阅读系列】之 Dubbo XML 配置加载
今天我们来谈谈 Dubbo XML 配置相关内容.关于这部分内容我打算分为以下几个部分进行介绍: Dubbo XML Spring 自定义 XML 标签解析 Dubbo 自定义 XML 标签解析 Du ...
- spring 5.x 系列第15篇 —— 整合dubbo (xml配置方式)
文章目录 一. 项目结构说明 二.项目依赖 三.公共模块(dubbo-common) 四. 服务提供者(dubbo-provider) 4.1 productService是服务的提供者( 商品数据用 ...
- Dubbo xml配置 和注解配置 写法
<?xml version="1.0" encoding="UTF-8"?><!-- - Copyright 1999-2011 Alibab ...
- dubbo高级配置学习
启动时检查 可以通过check="false"关闭检查,比如,测试时,有些服务不关心,或者出现了循环依赖,必须有一方先启动. 关闭某个服务的启动时检查:(没有提供者时报错) < ...
- dubbo高级配置学习(上)
启动时检查 Dubbo缺省会在启动时检查依赖的服务是否可用,不可用时会抛出异常,阻止Spring初始化完成,以便上线时,能及早发现问题,默认check=true. 如果你的Spring容器是懒加载的, ...
- dubbo源码分析7——dubbo的配置解析_与spring的整合
dubbo的配置其实就是建立在spring的命名空间的配置机制之上的.在dubbo的jar包的META-INF目录下会有spring.handlers这个文件,用来配置spring的命名空间和解析类的 ...
- 【原】Spring和Dubbo基于XML配置整合过程
背景 随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进. 单一应用架构 当网站流量很小时,只需一个 ...
- Dubbo SPI 机制源码分析(基于2.7.7)
Dubbo SPI 机制涉及到 @SPI.@Adaptive.@Activate 三个注解,ExtensionLoader 作为 Dubbo SPI 机制的核心负责加载和管理扩展点及其实现.本文以 E ...
- 阿里巴巴Dubbo实现的源码分析
1. Dubbo概述 Dubbo是阿里巴巴开源出来的一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及作为SOA服务治理的方案.它的核心功能包括: #remoting ...
随机推荐
- 【微信开发】【Asp.net MVC】-- 微信分享功能
内嵌在微信中的网页,右上角都会有一个默认的分享功能.如下图所示,第一个为自定义的效果,第二个为默认的效果.实现了自定义的分享链接是不是更让人有点击的欲望?下面讲解下开发的过程. 一.准备,设置js接口 ...
- C#异步的世界【上】
新进阶的程序员可能对async.await用得比较多,却对之前的异步了解甚少.本人就是此类,因此打算回顾学习下异步的进化史. 本文主要是回顾async异步模式之前的异步,下篇文章再来重点分析async ...
- quagga源码分析--大内总管zebra
zebra,中文翻译是斑马,于是我打开了宋冬野的<斑马,斑马>作为BGM来完成这个篇章,嘿嘿,小资一把! zebra姑且戏称它是quagga项目的大内总管. 因为它负责管理其他所有协议进程 ...
- SQL server Cannot find one or more
最近刚安装完sqlserver,新鲜感还没过,却出现了一大堆错误,令人头疼,其中有一个错误:在启动Microsoft SQL Server Management Studio时,出现如下错误提示,程序 ...
- Ubuntu 16.04 samba相关配置
samba是 SMB/CIFS网络协议的重新实现,它作为NFS的补充使得在Linux和Windows系统之间进行文件共享.打印更容易实现. 相关介绍: SAMBA套件: (1)samba:这个套件主要 ...
- erlang虚拟机代码执行原理
转载:http://blog.csdn.NET/mycwq/article/details/45653897 erlang是开源的,很多人都研究过源代码.但是,从erlang代码到c代码,这是个不小 ...
- mybatis分页控件
https://my.oschina.net/miemiedev/blog/135516
- XTU 1250 Super Fast Fourier Transform
$2016$长城信息杯中国大学生程序设计竞赛中南邀请赛$H$题 排序,二分. 对$a$数组,$b$数组从小到大进行排序. 统计每一个$a[i]$作为较大值的时候与$b[i]$对答案的贡献.反过来再统计 ...
- vb.net 结束进程
Public Class Form1 Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click ...
- 变形属性 transform
transform功能可以实现文字或图像的旋转.绽放.倾斜.与移动: 注意点:1.其移动.旋转.倾斜.与绽放这4种效果的使用先后顺序不同,页面会显示不同的结果: 2.属性值有一个参数与有多个参数的别: ...