我有一个 Jenkins Maven 工作,它有一个用 BASH 编写的后期构建脚本。定期,当 post 脚本运行时,似乎某种 Maven 操作正在干扰 BASH 脚本,导致构建失败。
这是 Jenkins 控制台的一些示例输出
+ version_override='Downloading: http://clojars.org/repo/org/apache/maven/plugins/maven-metadata.xml
Downloading: http://clojars.org/repo/org/codehaus/mojo/maven-metadata.xml
Downloading: http://oss.sonatype.org/content/repositories/releases/org/apache/maven/plugins/maven-metadata.xml
Downloading: http://oss.sonatype.org/content/repositories/releases/org/codehaus/mojo/maven-metadata.xml
看看我的 BASH 变量是如何从 Maven 下载中获得赋值的?现在我不会肯定地说这就是正在发生的事情。也许只有两个输出流同时进入控制台,一个来自 Maven 更新存储库,另一个来自我的 BASH 构建后脚本。无论哪种方式,Maven 下载似乎都会干扰我的 BASH 脚本,因为它最终会使构建崩溃。
+ read config_path
+ '[' '!' -z http://clojars.org/repo/org/apache/maven/plugins/maven-metadata.xml ']'
+ http://clojars.org/repo/org/apache/maven/plugins/maven-metadata.xml
/usr/share/build-utils/lib/java.sh: line 115: http://clojars.org/repo/org/apache/maven/plugins/maven-metadata.xml: No such file or directory
这绝对看起来像 Maven 输出正在潜入我的 BASH 脚本!
我几乎可以肯定这是 Maven 正在寻找更新。奇怪的是为什么它会与后期构建脚本并行运行。即便如此,它怎么可能会干扰所述脚本的运行时间?真是离奇!
我确定我的后期构建脚本没有任何问题的另一个原因。每次出现此错误时,我都会再次运行构建并且它可以工作。只有在 Maven 更新时,构建才会失败。
我不在乎 Maven 是否要查找更新,但是有没有办法配置它,以便在我的后期构建脚本之前发生 repo 更新?
终于想通了!我正在使用 Maven 插件通过 Maven 插件提取模块版本,基于这篇 SO 文章。
该命令产生这样的输出
我最初的 BASH 调用以提取版本号
然而,每隔一段时间(但不确定在哪里控制它),Maven 会联系更新模块(我认为)。这就是虚假的Downloading输出的来源,这与我从上面的分配相混淆。
我现在修改了命令如下
虽然可能仍然不是防弹的,谁知道这个命令可能会产生什么其他输出,例如有一天而不是前导[INFO]行,也许它会吐出[ERROR]或其他东西......
反正暂时收紧了。起初我确实认为这是一个 Jenkins/Maven 问题,但事实证明这只是一个 BASH 脚本问题!