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 命令。