Dubbo服务治理篇——低版本Dub

简介: 使用低版本Dubbo时,因为要与4.x与5.x版本的Spring集成,所以,我们需要做如下修改。

使用低版本Dubbo时,因为要与4.x与5.x版本的Spring集成,所以,我们需要做如下修改。


一、与4.x、5.x版本的Spring共存


首先需要排除掉dubbo自带的2.5的Spring,所以我使用下面这个配置,前面都是正常的引用Spring 4.x或Spring 5.x。


<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>dubbo</artifactId>
    <version>2.5.3</version>
    <exclusions>
        <exclusion>
            <groupId>org.springframework</groupId>
            <artifactId>spring</artifactId>
        </exclusion>
        <exclusion>
            <artifactId>netty</artifactId>
            <groupId>org.jboss.netty</groupId>
        </exclusion>
    </exclusions>
</dependency>
<dependency>
    <groupId>org.apache.zookeeper</groupId>
    <artifactId>zookeeper</artifactId>
    <version>3.4.6</version>
</dependency>
<dependency>
    <groupId>com.github.sgroschupf</groupId>
    <artifactId>zkclient</artifactId>
    <version>0.1</version>
</dependency>


二、打包成本地APP


需要使用Shade这个插件来打包,POM配置如下,其中最关键是那两个transformer,保证将spring.handlers和spring.schemas文件能合并起来,否则执行时会报找不到dubbo:application错误,或者说无法处理dubbo:application错,都是因为在缺省的打包模式下,META-INF目录下同名文件是只取第一个,而不会多个合并起来,导致找不到dubbo.xsd以及对应的handler类:


<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-shade-plugin</artifactId>
    <version>2.4.2</version>
    <configuration>
        <transformers>
            <transformer
                implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                <manifestEntries>
                    <Main-Class>cn.chinaunicom.woplus.analysis.MongoStatisticServer.App</Main-Class>
                    <X-Compile-Source-JDK>1.7</X-Compile-Source-JDK>
                    <X-Compile-Target-JDK>1.7</X-Compile-Target-JDK>
                </manifestEntries>
            </transformer>
            <transformer
                implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
                <resource>META-INF/spring.schemas</resource>
            </transformer>
            <transformer
                implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
                <resource>META-INF/spring.handlers</resource>
            </transformer>
        </transformers>
    </configuration>
    <executions>
        <execution>
            <phase>package</phase>
            <goals>
                <goal>shade</goal>
            </goals>
        </execution>
    </executions>


至此,完成配置,是不是So Easy呢?

相关文章
|
XML 负载均衡 Dubbo
Dubbo的高级特性:服务治理篇
大家好,我是王有志。今天我们一起来了解并学习如何使用Dubbo在服务治理方面提供的高级特性。
104 1
|
Dubbo Java 应用服务中间件
带你读《Apache Dubbo微服务开发从入门到精通》——三、 网关(5)
带你读《Apache Dubbo微服务开发从入门到精通》——三、 网关(5)
111 5
|
Dubbo Java 应用服务中间件
带你读《Apache Dubbo微服务开发从入门到精通》—— 一、 限流降级(中)
带你读《Apache Dubbo微服务开发从入门到精通》—— 一、 限流降级(中)
156 7
|
监控 Dubbo Java
带你读《Apache Dubbo微服务开发从入门到精通》—— 一、 限流降级(上)
带你读《Apache Dubbo微服务开发从入门到精通》—— 一、 限流降级(上)
150 6
|
Dubbo 应用服务中间件 API
带你读《Apache Dubbo微服务开发从入门到精通》——二、 分布式事务
带你读《Apache Dubbo微服务开发从入门到精通》——二、 分布式事务
179 6
|
开发框架 负载均衡 Dubbo
带你读《Apache Dubbo微服务开发从入门到精通》——三、 网关(3)
带你读《Apache Dubbo微服务开发从入门到精通》——三、 网关(3)
149 4
|
XML 开发框架 负载均衡
带你读《Apache Dubbo微服务开发从入门到精通》——三、 网关(1)
带你读《Apache Dubbo微服务开发从入门到精通》——三、 网关(1)
201 2
|
Kubernetes 负载均衡 Dubbo
带你读《Apache Dubbo微服务开发从入门到精通》——四、服务网格(1)
带你读《Apache Dubbo微服务开发从入门到精通》——四、服务网格(1)
194 4
|
缓存 Dubbo 应用服务中间件
带你读《Apache Dubbo微服务开发从入门到精通》——三、 网关(6)
带你读《Apache Dubbo微服务开发从入门到精通》——三、 网关(6)
135 6
|
Kubernetes Dubbo 应用服务中间件
带你读《Apache Dubbo微服务开发从入门到精通》——四、服务网格(6)
带你读《Apache Dubbo微服务开发从入门到精通》——四、服务网格(6)
137 5
下一篇
无影云桌面