案例现象
服务提供方修改了 对外提供的 api jar 包版本,并且 deploy jar 包到 maven 私服。调用方在编译的时候,打包或者运行的时候报 找不到类/noSuchMethodError。
解决方案
在依赖此 jar 包项目的 pom 文件中,增加如下配置,即可解决。
<repositories>
<repository>
<id>私服 ID</id>
<url>http://私服 IP 和 port/nexus/content/groups/public/</url>
<snapshots>
<updatePolicy>always</updatePolicy>
</snapshots>
</repository>
</repositories>
问题原因
1.如果在 web 项目中出现此错误,大概率是因为 调用方在之前编译的过程,已经下载过此版本的快照版。
而 maven 默认的 snapshot 更新策略是每天都更新。 在一天内deploy 多次到 maven 私服,调用方重新编译的时候很可能拉取不到最新的snapshot jar 包,导致报错。
2.如果是以 jar 方式启动,可能需要另外一种解决方式。 原因是在生成 jar 包的时候,jar 中的 MANIFEST.MF 中配置 classpath 时候,将snapshot 包打成带时间戳的snapshot 版本。
解决方案如下:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<configuration>
<archive>
<manifest>
<addClasspath>true</addClasspath>
<classpathPrefix>lib/</classpathPrefix>
<mainClass>main 类入口</mainClass>
<useUniqueVersions>false</useUniqueVersions>
</manifest>
</archive>
</configuration>
</plugin>
知识储备
1.解决此类问题,需要知道 maven 本地仓库,私服,中央仓库的关系。
2.maven 打包时候获取 snapshot 的默认更新规则。
3.以 jar 方式启动的项目,如何指定 classPath ,以及含有 snapshot 依赖的时候默认的处理规则。
参考文章:
https://www.iteye.com/blog/zh-ka-163-com-2227702
https://www.iteye.com/blog/breezylee-2421968