【发布时间】:2015-12-10 13:28:50
【问题描述】:
我正在尝试让 maven 下载所有依赖项(编译、测试、插件等),这样我就可以避免让我们的 dockerized 构建浪费不必要的时间一遍又一遍地下载它们。
我们已经对我们的 maven 构建进行了 docker 化,这样我们就可以从我们的 jenkins 运行它,而无需在 jenkins 机器上安装大量构建特定的依赖项(Java、redis、maven 依赖项等)。我们的构建依赖于增量 docker 构建,它只执行实际需要重新运行的步骤。
我们的主要构建是一个DockerFile,它有几个步骤来安装jdk、maven等。然后它做了一个
COPY ./pom.xml /opt/inbot-api/pom.xml
RUN mvn dependency:copy-dependencies clean
这会将依赖项下载到本地 maven 存储库,然后清除目标目录。
然后我们将源代码树复制到映像并运行完整的构建。
COPY ./src /opt/inbot-api/src
RUN mvn -e clean install
一般的想法是,在干净的机器上,docker 将执行所有的 RUN 步骤,但在增量构建上它只会重新运行需要重新运行的东西。在每个运行步骤之后,它都会存储一个中间图像。因此,如果 pom 文件没有更改,则无需重新运行依赖项获取步骤,因为它会产生完全相同的结果。因此,它会加载已下载的所有依赖项的缓存中间图像。这正是我们想要的。
我们的 DockerFile 有很多东西在这里并不那么相关,但最终它会生成一个 docker 文件,其中包含我们编译的工件、一个 nginx 配置和我们可以部署到 ECS 的所有运行时依赖项。
这几乎可以工作,除了mvn clean install 仍然会在每个构建中下载额外的插件依赖项。因此,这些是复制依赖项步骤未涵盖的依赖项。
我的问题,我如何让RUN mvn dependency:copy-dependencies clean 下载所有依赖项,包括插件依赖项。我见过人们实际上使用mvn verify clean 而不是mvn dependency:copy-dependencies clean,但在我们的情况下这有点慢。我想知道是否有更好的方法来做到这一点。
如果有任何关于如何改进的反馈,我将不胜感激。
更新
我现在做一个
RUN mvn -B -T 4 dependency:copy-dependencies dependency:resolve-plugins dependency:go-offline clean
之后它仍然使用mvn clean install 下载更多内容。尽管dependency:go-offline,mvn -o clean install 仍然失败。所以,这个插件好像坏了。
【问题讨论】:
-
对于插件我建议使用
mvn dependency:resolve-plugins见maven.apache.org/plugins/maven-dependency-plugin/… -
谢谢,问题解决了。
-
请在stackoverflow.com/a/71066133/418599查看我的解决方案。
-
谢谢,但我早就停止使用 maven;我现在正在使用 Gradle。当然,哪一个在离线使用方面有自己的挑战。