dubbo于spring框架结合,为了让dubbo配置与spring框架语义更贴近,所以会选择基于spring的XML扩展方式,来表示自己的特有的一些配置方式。所以这里先来看看spring中的schema(模式文档)。如何基于Spring来扩展自己的特有的标签。
完成一个自定义配置一般需要以下步骤:
1)设计配置属性和JavaBean
2)编写XSD文件
3)编写NamespaceHandler和BeanDefinitionParser完成解析工作
4)编写spring.handlers和spring.schemas串联起所有文件
5)应用
下面写一个实例来完成以上的步骤:
1)建一个JavaBean
public class Customer {
private String id;
/** 客户名称 */
private String custName;
/** 联系电话 */
private String contactPhone;
/** 联系邮箱 */
private String email;
}
2)编写XSD文件
为上一步的JavaBean编写XSD文件,XSD是schema的定义文件,配置的输入和解析输出都是以XSD为契约。
<?xml version="1.0" encoding="UTF-8"?>
<xsd:schema
xmlns="http://jishuaige.iteye.com/admin/blogs/schema/customer"
xmlns:xsd="http://www.w3.org/2001/XMLSchema"
xmlns:beans="http://www.springframework.org/schema/beans"
targetNamespace="http://jishuaige.iteye.com/admin/blogs/schema/customer"
elementFormDefault="qualified"
attributeFormDefault="unqualified">
<xsd:import namespace="http://www.springframework.org/schema/beans" />
<xsd:element name="customer">
<xsd:complexType>
<xsd:complexContent>
<xsd:extension base="beans:identifiedType">
<xsd:attribute name="custName" type="xsd:string" />
<xsd:attribute name="contactPhone" type="xsd:string" />
<xsd:attribute name="email" type="xsd:string" />
</xsd:extension>
</xsd:complexContent>
</xsd:complexType>
</xsd:element>
</xsd:schema>
关于xsd:schema的各个属性具体含义可以参考:http://www.w3school.com.cn/schema
<xsd:element name="customer">配置项节点的名称,在应用中会使用这个名字来引用配置。
<xsd:attribute/>配置bean的属性和类型
完成XSD文件后,把xsd存放在classpath下,一般都放在META-INF目录下。
3)编写NamespaceHandler和BeanDefinitionParser完成解析工作
NamespaceHandler:会根据XSD文件中的节点名称找到自己制定的BeanDefinitionParser,然后由BeanDefinitionParser完成具体的解析工作。spring提供了这个2个类的默认实现类:NamespaceHandlerSupport和AbstractSingleBeanDefinitionParser,最简单的就是直接继承这2个类。
import org.springframework.beans.factory.xml.NamespaceHandlerSupport;
public class CustomerNamespaceHandlerSupport extends NamespaceHandlerSupport {
@Override
public void init() {
registerBeanDefinitionParser("customer", new CustomerBeanDefinitionParser());
}
}
registerBeanDefinitionParser("customer", new CustomerBeanDefinitionParser());方法就是把节点名称customer和解析类联系起来。配置项中的customer使用CustomerBeanDefinitionParser类解析配置。
import org.springframework.beans.factory.support.BeanDefinitionBuilder;
import org.springframework.beans.factory.xml.AbstractSingleBeanDefinitionParser;
import org.springframework.util.StringUtils;
import org.w3c.dom.Element;
public class CustomerBeanDefinitionParser extends AbstractSingleBeanDefinitionParser {
@Override
protected void doParse(Element element, BeanDefinitionBuilder builder) {
String custName = element.getAttribute("custName");
String contactPhone = element.getAttribute("contactPhone");
String email = element.getAttribute("email");
String id = element.getAttribute("id");
if (StringUtils.hasText(id)) {
builder.addPropertyValue("id", id);
}
if (StringUtils.hasText(custName)) {
builder.addPropertyValue("custName", custName);
}
if (StringUtils.hasText(contactPhone)) {
builder.addPropertyValue("contactPhone", contactPhone);
}
if (StringUtils.hasText(email)) {
builder.addPropertyValue("email", email);
}
}
@Override
protected Class<?> getBeanClass(Element element) {
return Customer.class;
}
}
element.getAttribute:获取配置文件中的值,bean.addPropertyValue:把属性值放到bean中。
4)编写spring.handlers和spring.schemas串联起所有文件
Javabean,XSD文件,解析类都准备好了。现在是应该把他们串起来了。让他们能够协调工作。
spring提供了两个配置文件来完成串起来的工作,这两个文件的地址必须是META-INF/spring.handlers和META-INF/spring.schemas,spring会默认去载入它们。
spring.handlers:
http\://jishuaige.iteye.com/admin/blogs/schema/customer=com.jishuaige.schema.CustomerNamespaceHandlerSupport
当使用到名为"http\://jishuaige.iteye.com/admin/blogs/schema/customer"的schema引用时,会通过com.jishuaige.schema.CustomerNamespaceHandlerSupport来完成解析
spring.schemas:
http\://jishuaige.iteye.com/admin/blogs/schema/customer.xsd=META-INF/customer.xsd
5)应用
现在简单的配置已经完成了,现在就应该应用到具体的实例中了。下面来配置一个spring bean,要基于我们自己的schema(模式文档)。以下是配置文件:
<?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:customer="http://jishuaige.iteye.com/admin/blogs/schema/customer"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://jishuaige.iteye.com/admin/blogs/schema/customer http://jishuaige.iteye.com/admin/blogs/schema/customer.xsd">
<customer:customer id="001" custName="jishuaige" contactPhone="13600000000" email="123@123.com"/>
</beans>
xmlns:customer="http://jishuaige.iteye.com/admin/blogs/schema/customer"指定我们自定义的schema。xsi:schemaLocation指定xsd文件。
<customer:customer/>配置使用的实例。
下面我们来使用我们定义的这个BEAN:
ApplicationContext ctx = new ClassPathXmlApplicationContext("application.xml");
Customer customer = (Customer) ctx.getBean("001");
上面就是我对于spring可扩展schema的提供自定义配置支持的一些理解和具体的操作。后面就在dubbo中看看实际的应用了。
分享到:
相关推荐
标题 "springboot2.0.x+dubbo-spring-boot-starter" 涉及的是将流行的微服务框架 Dubbo 集成到 Spring Boot 2.0.x 的项目实践中。这个集成使得开发者能够利用 Spring Boot 的便利性和 Dubbo 的高性能远程服务调用...
本人实际测试过,这两个包可用。...2.修改dubbo-monitor中的conf目录中的dubbo.properties dubbo.registry.address 与 dubbo-admin中的配置一样 3.到dubbo-monitor中的bin目录下运行 start.sh脚本 ok
dubbo源码dubbo-dubbo-2.7.3.rardubbo源码dubbo-dubbo-2.7.3.rardubbo源码dubbo-dubbo-2.7.3.rardubbo源码dubbo-dubbo-2.7.3.rardubbo源码dubbo-dubbo-2.7.3.rardubbo源码dubbo-dubbo-2.7.3.rardubbo源码dubbo-dubbo...
【描述】中提到的 "这是一款dubbo的控制台管理工具,下载下来放在Tomcat目录下可以直接使用",意味着 Dubbo-admin 是用来管理和监控 Dubbo 服务的一个图形用户界面。用户可以通过它来查看、管理和操作Dubbo服务,...
3. **构建与运行**:下载的dubbo-admin通常是一个源码包,如描述中的`dubbo-2.8.4`,这个可能是整个Dubbo框架的一个版本,而不是单独的admin部分。你需要使用Maven或Gradle等构建工具来编译和打包项目。对于dubbo-...
【标题】"incubator-dubbo-dubbo-2.5.8" 是一个基于Java的开源服务框架,由Apache孵化器项目提供。这个版本是Dubbo的2.5.8稳定版,它包含了Dubbo的核心服务治理功能以及一个专门的管理平台——dubbo-admin。 【描述...
在实际部署中,`dubbo-monitor-simple-2.5.4-SNAPSHOT-assembly.tar.gz`包含了Dubbo监控的组件,解压后可以配置启动,使得消费者和服务提供者能将调用信息上报到监控中心。`dubbo-demo-consumer-2.5.4-SNAPSHOT-...
Dubbo是由阿里巴巴开源的高性能、轻量级的服务治理框架,而dubbo-admin则是Dubbo生态中的一个重要组件,它提供了图形化的服务治理工具,帮助开发者进行服务的注册、发现、监控和管理。 【压缩包子文件的文件名称...
【标题】"incubator-dubbo-dubbo-2.6.1" 是一个Apache Incubator项目Dubbo的特定版本,这里的2.6.1表示该版本是Dubbo的稳定分支之一。 【描述】提到的"incubator-dubbo-dubbo-2.6.1"表明这是Apache孵化器中的Dubbo...
综上所述,Apache Incubator Dubbo-OPS Master是Dubbo生态系统中的重要组成部分,它提供了强大的管理和监控能力,为开发者带来了极大的便利,也是构建高效、稳定的分布式系统不可或缺的工具。对于Java开发者,尤其是...
dobbo源码dubbo-dubbo-2.7.3.rardobbo源码dubbo-dubbo-2.7.3.rardobbo源码dubbo-dubbo-2.7.3.rardobbo源码dubbo-dubbo-2.7.3.rardobbo源码dubbo-dubbo-2.7.3.rardobbo源码dubbo-dubbo-2.7.3.rardobbo源码dubbo-dubbo...
其中,`dubbo-admin`是Dubbo的核心组件之一,它提供了一个可视化的管理控制台,帮助开发者对服务进行管理和监控。本文将详细解析`dubbo-admin-2.5.4.war`这个版本的后台管理工具,探讨其主要特性和使用方法。 首先...
jmeter的dubbo插件,jmeter-plugins-dubbo-2.7.8-jar-with-dependencies.jar,适用于JMeter5.4.1版本,将解压后的文件jmeter-plugins-dubbo-2.7.8-jar-with-dependencies放在Jmeter安装目录下的\lib\ext文件夹中,...
《Dubbo监控工具详解——基于dubbo-monitor-simple-2.5.8》 在分布式系统开发中,监控是至关重要的一个环节,它可以帮助开发者实时了解服务的运行状态,及时发现并解决问题。Apache Dubbo,作为一款高性能、轻量级...
【压缩包子文件的文件名称列表】中的"**dubbo-admin-2.5.8.war**"是这个压缩包的主要内容,解压后会得到一个完整的Web应用,只需将其放入Web服务器的webapps目录下,启动服务器即可使用。 在使用dubbo-admin时,...
dubbo-admin打包后的文件,扔到tomcat里就能跑起来!dubbo-admin打包后的文件,扔到tomcat里就能跑起来!dubbo-admin打包后的文件,扔到tomcat里就能跑起来!
1. `jmeter-plugins-dubbo-2.7.1-jar-with-dependencies.jar`:这是一个包含所有依赖的完整版本JAR文件,用户可以直接将其引入到JMeter中使用,无需额外配置类路径。 2. `jmeter-plugins-dubbo-2.7.1.jar`:这是插件...
dubbo官方自带了dubbo-admin及dubbo-simple/dubbo-monitor-simple二个子项目用于服务治理及服务监控。 dubbo-monitor-simple是Alibaba的开源项目,用于监控在dubbo框架下接口暴露,注册情况,也可以看接口的调用...
7. **部署与使用**:在实际应用中,用户需要将dubbo-admin.war部署到服务器上的Servlet容器,然后启动dubbo-monitor的tar.gz文件中的服务,这样就可以通过Web界面管理Dubbo服务并监控其运行情况了。 总结,这个...