Maven 干扰 Jenkins 构建后脚本

Maven 干扰 Jenkins 构建后脚本

我有一个 Jenkins Maven 作业,其中有一个用 BASH 编写的后期构建脚本。在后期脚本运行时,似乎某些 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 更新我的后期构建脚本?

答案1

终于搞定了!我使用 Maven 插件通过 Maven 插件提取模块版本,基于这篇文章

该命令产生如下输出

[INFO] --- maven-help-plugin:2.1.1:evaluate (default-cli) @ master-parent ---
[INFO] No artifact parameter specified, using 'com.myorg:master-parent:pom:0.3.02' as project.
[INFO] 
0.3.02
[INFO] ------------------------------------------------------------------------
[INFO] Reactor Summary:
[INFO] 

我最初调用 BASH 来提取版本号

version_override=$(mvn org.apache.maven.plugins:maven-help-plugin:2.1.1:evaluate -Dexpression=project.version | grep -v '[INFO]')

然而,每隔一段时间(但不确定在哪里控制),Maven 就会向模块发出更新请求(我认为)。这就是虚假的下载输出来自,这与我上面的任务相混淆。

我现在修改了命令如下

version_override=$(mvn org.apache.maven.plugins:maven-help-plugin:2.1.1:evaluate -Dexpression=project.version | egrep -v '[INFO]|Downloading:' | tr -d ' \n')

但可能仍然不是万无一失的,谁知道这个命令可能还会产生什么其他输出,例如有一天它不会领先[信息]线条,也许会吐出来[错误]或者其他的东西...

无论如何,它暂时收紧了。一开始我确实认为这是一个 Jenkins/Maven 问题,但结果发现这只是一个 BASH 脚本问题!

相关内容