maven那个版本最好用_Maven快照版本要这样用才真的香!

本文讲述了在使用Maven时遇到的类找不到问题,由于快照版本加时间戳导致classpath与lib目录下的jar包不一致。通过分析MANIFEST.MF文件找到问题关键,并提出了解决方案,涉及maven-jar-plugin和maven-assembly-plugin的配置调整,以避免快照版本的时间戳问题。最后推荐使用spring-boot-maven-plugin进行打包。
摘要由CSDN通过智能技术生成

Bug的身世之谜

今天又分享一个问题解决的故事。请看下图框起来的错误,明显就是找不到这个class嘛!

f0167ab49b79355642b1f4d5db71dbcf.png

下面我们按照正常人的思路去排查这个问题,既然找不到class那就先看这个依赖的jar包有没有,如果没有那就是铁证如山。

但是事与愿违啊,编译后的lib目录下真的有这个包o****rder-api-2.0-SNAPSHOT.jar

还是不相信,于是将order-api-2.0-SNAPSHOT.jar解压了,看看里面到底有没有我们需要的class,真的有,此处心情沉重。

一般人到这里就会懵圈了,但我还年轻啊,脑袋还够用。接下来看看classpath的配置有没有问题,如果order-api-2.0-SNAPSHOT.jar不在classpath中,那么自然就是找不到class啊,机智的我。

于是查看了META-INF/MANIFEST.MF文件,发现里面依赖的是order-api-2.0-20200225.024541-15.jar,什么情况,还加上时间戳了。

终于真相大白了,classpath中指向的是order-api-2.0-20200225.024541-15.jar,但lib中只有order-api-2.0-SNAPSHOT.jar。所以找不到class是没有错的。

打包配置信息

Maven deploy的时候会自动给快照版本加时间戳,从下图可以看的出来:

eb1599df42829145ab6c212ced522bb6.png

下面来看下目前项目的打包配置,如下:

org.apache.maven.plugins  maven-jar-plugin  2.3.1com.xxx.web.WebApp        true        lib/org.apache.maven.plugins  maven-assembly-plugin

用了assembly插件,对应的配置如下:

assembly.xml

binzipfalse/false${artifact}xxx-web.jar/libfalsefalse

打包后目录中会有一个jar包和一个lib目录,如下:

-xxx-web.jar-lib  -xxx.jar  -yyy.jar

解决方案

现在需要解决的问题是classpath中的快照依赖和lib目录中实际的jar包不一致的问题。

主要是两个插件,所以才会有不一致的情况。

maven-jar-plugin插件中可以加上false来强制打包时 MANIFEST.MF文件不记录的Jar时间戳版本。

maven-assembly-plugin插件需要在assembly.xml中进行修改,在dependencySet中增加outputFileNameMapping=${artifact.artifactId}-${artifact.baseVersion}.${artifact.extension}

来固定名称,这样就可以去掉时间戳了。

下面贴一下修改之后完整的配置:

org.apache.maven.plugins  maven-jar-plugin  2.3.1com.xxx.web.WebApp        true        lib/falseorg.apache.maven.plugins  maven-assembly-plugin

assembly.xml

binzipfalse/false${artifact}xxx-web.jar  ${artifact.artifactId}-${artifact.baseVersion}.${artifact.extension}          /libfalsefalse

虽然解决了,但感觉还是挺麻烦的。还是spring-boot-maven-plugin插件好用啊,至少没有出现过这个时间戳的问题,新项目建议大家用spring-boot-maven-plugin插件打包。

关于作者:尹吉欢,简单的技术爱好者,《Spring Cloud微服务-全栈技术与案例解析》, 《Spring Cloud微服务 入门 实战与进阶》作者, 公众号 猿天地发起人。

75bdf4d147486946c1a78eac6b436ccc.png

微信搜一搜关注我吧

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值