`
jishuaige
  • 浏览: 10312 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

dubbo-探索之旅(五)---spring中的schema

 
阅读更多
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

    标题 "springboot2.0.x+dubbo-spring-boot-starter" 涉及的是将流行的微服务框架 Dubbo 集成到 Spring Boot 2.0.x 的项目实践中。这个集成使得开发者能够利用 Spring Boot 的便利性和 Dubbo 的高性能远程服务调用...

    dubbo-admin-2.5.4及dubbo-monitor-2.5.3 安装及配置

    本人实际测试过,这两个包可用。...2.修改dubbo-monitor中的conf目录中的dubbo.properties dubbo.registry.address 与 dubbo-admin中的配置一样 3.到dubbo-monitor中的bin目录下运行 start.sh脚本 ok

    dubbo-dubbo-2.7.3.rar

    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-admin-2.5.4.war

    【描述】中提到的 "这是一款dubbo的控制台管理工具,下载下来放在Tomcat目录下可以直接使用",意味着 Dubbo-admin 是用来管理和监控 Dubbo 服务的一个图形用户界面。用户可以通过它来查看、管理和操作Dubbo服务,...

    dubbo-admin的下载

    3. **构建与运行**:下载的dubbo-admin通常是一个源码包,如描述中的`dubbo-2.8.4`,这个可能是整个Dubbo框架的一个版本,而不是单独的admin部分。你需要使用Maven或Gradle等构建工具来编译和打包项目。对于dubbo-...

    incubator-dubbo-dubbo-2.5.8

    【标题】"incubator-dubbo-dubbo-2.5.8" 是一个基于Java的开源服务框架,由Apache孵化器项目提供。这个版本是Dubbo的2.5.8稳定版,它包含了Dubbo的核心服务治理功能以及一个专门的管理平台——dubbo-admin。 【描述...

    dubbo-demo-consumer、dubbo-demo-provider、dubbo-simple-monitor

    在实际部署中,`dubbo-monitor-simple-2.5.4-SNAPSHOT-assembly.tar.gz`包含了Dubbo监控的组件,解压后可以配置启动,使得消费者和服务提供者能将调用信息上报到监控中心。`dubbo-demo-consumer-2.5.4-SNAPSHOT-...

    dubbo-admin包

    Dubbo是由阿里巴巴开源的高性能、轻量级的服务治理框架,而dubbo-admin则是Dubbo生态中的一个重要组件,它提供了图形化的服务治理工具,帮助开发者进行服务的注册、发现、监控和管理。 【压缩包子文件的文件名称...

    incubator-dubbo-dubbo-2.6.1

    【标题】"incubator-dubbo-dubbo-2.6.1" 是一个Apache Incubator项目Dubbo的特定版本,这里的2.6.1表示该版本是Dubbo的稳定分支之一。 【描述】提到的"incubator-dubbo-dubbo-2.6.1"表明这是Apache孵化器中的Dubbo...

    incubator-dubbo-ops-master.rar

    综上所述,Apache Incubator Dubbo-OPS Master是Dubbo生态系统中的重要组成部分,它提供了强大的管理和监控能力,为开发者带来了极大的便利,也是构建高效、稳定的分布式系统不可或缺的工具。对于Java开发者,尤其是...

    dobbo源码dubbo-dubbo-2.7.3.rar

    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-2.5.4.war后台管理

    其中,`dubbo-admin`是Dubbo的核心组件之一,它提供了一个可视化的管理控制台,帮助开发者对服务进行管理和监控。本文将详细解析`dubbo-admin-2.5.4.war`这个版本的后台管理工具,探讨其主要特性和使用方法。 首先...

    jmeter-plugins-dubbo-2.7.8-jar-with-dependencies.jar

    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-monitor-simple-2.5.8-assembly.tar.gz

    《Dubbo监控工具详解——基于dubbo-monitor-simple-2.5.8》 在分布式系统开发中,监控是至关重要的一个环节,它可以帮助开发者实时了解服务的运行状态,及时发现并解决问题。Apache Dubbo,作为一款高性能、轻量级...

    dubbo-admin包,dubbo-admin.war,基于github中dubbo源码打包,亲测可用。

    【压缩包子文件的文件名称列表】中的"**dubbo-admin-2.5.8.war**"是这个压缩包的主要内容,解压后会得到一个完整的Web应用,只需将其放入Web服务器的webapps目录下,启动服务器即可使用。 在使用dubbo-admin时,...

    dubbo-admin-2.5.5.war

    dubbo-admin打包后的文件,扔到tomcat里就能跑起来!dubbo-admin打包后的文件,扔到tomcat里就能跑起来!dubbo-admin打包后的文件,扔到tomcat里就能跑起来!

    jmeter-plugins-dubbo-2.7.1-jar-with-dependencies

    1. `jmeter-plugins-dubbo-2.7.1-jar-with-dependencies.jar`:这是一个包含所有依赖的完整版本JAR文件,用户可以直接将其引入到JMeter中使用,无需额外配置类路径。 2. `jmeter-plugins-dubbo-2.7.1.jar`:这是插件...

    dubbo-monitor-simple-2.6.1.tgz

    dubbo官方自带了dubbo-admin及dubbo-simple/dubbo-monitor-simple二个子项目用于服务治理及服务监控。 dubbo-monitor-simple是Alibaba的开源项目,用于监控在dubbo框架下接口暴露,注册情况,也可以看接口的调用...

    dubbo-admin dubbo-monitor.zip 2.8.4可用

    7. **部署与使用**:在实际应用中,用户需要将dubbo-admin.war部署到服务器上的Servlet容器,然后启动dubbo-monitor的tar.gz文件中的服务,这样就可以通过Web界面管理Dubbo服务并监控其运行情况了。 总结,这个...

Global site tag (gtag.js) - Google Analytics