最近在开发过程中,发现工程中的一些包有问题,主要分为以下两种:

1、最新包(版本号未变,只是被更新了)少了一个方法

2、jar包被更新了,但是无法更新最新的包下来

首先先确定一下更新包会导致更新哪些文件?下面都以a-1.0.1-snapshot.jar包为例

当你更新了a-snapshot.jar的内容,并上传到maven服务器时,会更新一个元数据文件maven-metadata.xml,这个文件内容类似如下

<!--?xml version="1.0" encoding="UTF-8" standalone="no"?-->
<?xml?version="1.0"?encoding="UTF-8"?>
<metadata?modelVersion="1.1.0">
        ??<groupId>com.my.testu</groupId>
        ??<artifactId>a</artifactId>
        ??<version>1.0.1-SNAPSHOT</version>
        ??<versioning>
    <!--当前版本下的最新快照信息-->
? ??<snapshot>
        <!--快照的时间戳-->
  ? ? ??<timestamp>20160909.081828</timestamp>
        <!--构件号-->
  ? ? ??<buildNumber>34</buildNumber>
  ? ??</snapshot>
    <!--metadata文件被更新的时间-->
? ??<lastUpdated>20160909081828</lastUpdated>
? ??<snapshotVersions>
? ? ??<snapshotVersion>
  ? ? ? ??<extension>jar</extension>
          <!-- 这个就是最新的jar包前缀-->
  ? ? ? ??<value>1.0.1-20160909.081828-34</value>
  ? ? ? ??<updated>20160909081828</updated>
  ? ? ??</snapshotVersion>
? ? ??<snapshotVersion>
  ? ? ? ??<extension>pom</extension>
  ? ? ? ??<value>1.0.1-20160909.081828-34</value>
  ? ? ? ??<updated>20160909081828</updated>
  ? ? ??</snapshotVersion>
??</versioning>
</metadata>

这个文件是很重要的,你的每次提交都会更新这个文件,当从maven下载jar包时,也会根据这个文件进行jar包的查找。若这时你去更新jar包,会下载最新包a-1.0.1-20160909.081828-24.jar,下载到本地后会复制一份重命名为a-1.0.1-snapshot.jar。

对于刚才说的第二个问题,就是因为maven-metadata.xml文件中的timestamp和updated不一致,导致找不到最新包,一般可能会报错Missing artifact

从现在看,想解决这两个问题,就是需要制定相同版本号下某个更新之后的jar包,并不一定是最新包。

既然maven-metadata.xml文件在maven服务器上可以指定下载哪个jar包,那么本地是否也可以指定呢?答案是肯定的,本地jar包一般到在.m2/repository路径下,在jar包所在的目录下一般会存在maven-metadata.xml这个文件,可以复制一份重命名为maven-metadata-local.xml。

maven在build后会自动去Downloading 这个maven-metadata.xml文件,这个文件可以看作版本信息,作为一个版本比对。 在咱们使用maven更新工程的jar包时,其实maven是会比较服务器上的maven-metadata.xml和本地的maven-metadata-local.xml中的lastUpdated时间戳值,哪个值更大,就以哪个文件为准。这里需要注意的是,若是maven-metadata-local.xml文件的值大,这时候就中止下载了,直接使用本地的jar包,所以你得自己准备好自己想用的jar包。