场景:A开发小组开发了3个架包,分别是A1,A2,A3。这部分架包分别被系统B,C,D 三个系统引用。随着系统的发展,A开发小组对jar进行了升级,目前产线上有A1.1 A1.2 A1.3;B1.1 B1.2 B1.3;C1.2 C1.1 C1.3 C1.4 这几个版本。而B,C,D系统引用的 jar 各个版本都有,且A系统升级jar包后想让B,C,D都更新为最新的jar包比较困难,因为需要各种测试等。。。简单来说,就是推新架构较为困难。这个时候就需要静默升级,让应用系统感知不到。。。当然这样错有一定的风险,当新jar包理论上应该兼容旧jar包;
实现方式:使用pom做版本管理。
第一步:创建一个maven工程(项目AA),只作为jar版本管理。该项目中只用一个pom文件,内容如下
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.test</groupId>
<artifactId>runtime-parent</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>pom</packaging>
<dependencyManagement>
<dependencies>
<!-- https://mvnrepository.com/artifact/org.apache.dubbo/dubbo-common -->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-common</artifactId>
<version>2.7.2</version>
</dependency>
</dependencies>
</dependencyManagement>
</project>
第二步:创建一个maven项目(项目BB),也只有一个pom文件,但该项目已将需要的jar引入。之后将这个项目打成pom包,内容如下
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<groupId>com.test</groupId>
<artifactId>runtime-parent</artifactId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<groupId>com.test</groupId>
<artifactId>runtime</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>pom</packaging>
<dependencies>
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-common</artifactId>
</dependency>
</dependencies>
</project>
第三部:应用将第二部的pom包依赖进来(项目CC)
<dependency>
<groupId>com.test</groupId>
<artifactId>runtime</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
这样做,当需要jar升级的时候,只需将AA项目中的jar版本升级一下。当CC版本重新打包的时候,自动将最近的jar打入;
pom文件中依赖的包如果没有指定版本号,将自动向父pom中查找,直到找到版本号;