AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 543937
Accepted
quickshiftin
quickshiftin
Asked: 2013-10-05 14:53:33 +0800 CST2013-10-05 14:53:33 +0800 CST 2013-10-05 14:53:33 +0800 CST

Maven 干扰 Jenkins 后期构建脚本

  • 772

我有一个 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 更新?

jenkins
  • 1 1 个回答
  • 1058 Views

1 个回答

  • Voted
  1. Best Answer
    quickshiftin
    2013-10-09T12:28:36+08:002013-10-09T12:28:36+08:00

    终于想通了!我正在使用 Maven 插件通过 Maven 插件提取模块版本,基于这篇 SO 文章。

    该命令产生这样的输出

    [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 会联系更新模块(我认为)。这就是虚假的Downloading输出的来源,这与我从上面的分配相混淆。

    我现在修改了命令如下

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

    虽然可能仍然不是防弹的,谁知道这个命令可能会产生什么其他输出,例如有一天而不是前导[INFO]行,也许它会吐出[ERROR]或其他东西......

    反正暂时收紧了。起初我确实认为这是一个 Jenkins/Maven 问题,但事实证明这只是一个 BASH 脚本问题!

    • 2

相关问题

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve