【总结】maven 打包刷新下载依赖卡死

2023-05-16

问题现象

idea 打包或者刷新maven依赖,总是出现卡死情况。之后就不动了。
使用同样maven 命令打包也一样。

这个问题以前出现过,但后来又几次是关机重启idea,或者重启电脑,或者有时候莫名其妙的就自己好了。

打包命令:mvn clean package --update-snapshots -DskipTests=true package -P mysql,deploy -X

错误信息


通过执行maven 打包命令时,加上 -X 打印debug日志,发现每次卡住之前,日志都停留在:
“[DEBUG] Writing tracking file /Users/xxx.li/.m2/respository/cn//client/-metric-client/1.0.2-dev-****-SNAPSHOT/resolver-status.properties” .

而且都是卡在两个固定的二方包更新上。

排查分析

现象已经很明显,而且每次卡顿的点都是固定的。

于是根据过往经验,把本地仓库删掉,然后重新刷新依赖下载jar包,看看到底是下载哪个文件导致的卡顿。

经过多次试验,发现每次卡住之前,在下载被卡住的jar包时,在本地仓库,jar包目录下,会先生成两个文件。如下:
maven-metadata-spring-snapshot.xml.part
maven-metadata-spring-snapshot.xml.part.lock
在这里插入图片描述
最终猜测,可能是打包命令中 --update-snapshots 在项目工程maven依赖不合理的情况下,会导致maven 产生死锁。

完整命令:mvn clean package --update-snapshots -DskipTests=true package -P mysql,deploy -X

于是,手动将本地仓库需要下载更新的相关SNAPSHOT包删掉。

打包时,去掉 --update-snapshots 命令,打包完成。idea也是一样,去掉 --update-snapshots 选项,也可以顺利打包了。

但其实问题并没有根本解决,因为我们只是用手动删除的方式进行规避的。
以后idea都要关闭 --update-snapshots 选项,那岂不是很麻烦。

问题解决

问题并没有根本解决,怀疑是出问题的jar包依赖比较复杂,引起maven --update-snapshots 的时候,出现了死锁。

规避方法:手动删除需要更新的本地jar版本包,去掉 --update-snapshots 命令。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

【总结】maven 打包刷新下载依赖卡死 的相关文章

随机推荐