Jenkins 流水线和大量的并行步骤

标签 jenkins jenkins-pipeline jenkins-blueocean

我已经在整个互联网上搜索了 2 周,在 freenode IRC 和 Jenkins 用户组邮件列表中询问了这个问题,但没有得到答案,所以我在这里,你是我最后的希望(没有压力)

我有一个 Jenkins 脚本管道,它生成数百个并行分支,这些分支必须在数百个从节点上同时运行。目前看来 Jenkins BlueOcean 用户界面不适合这种情况。我们达到了无法显示所有步骤的地步。

我需要提供一些背景信息让您了解我们的需求:我们公司有一个庞大的项目,其中有数千个 Behat/Selenium,如果按顺序完成,现在需要超过 30 小时才能运行。我们之前实现了一个基本的解决方案,我们使用排队系统 (RabbitMq) 来存储所有测试和运行测试的消费者,方法是从 Jenkins 下载源代码并将工件也上传回 Jenkins,但这不像Jenkins 本地奴隶,它的可维护性不够(例如,我们没有从实时输出日志和使用统计中受益)。

我知道这里有一个 Unresolved 问题描述了这个问题:https://issues.jenkins-ci.org/browse/JENKINS-41205但是,基本上,我需要在下周工作的解决方法(我们的开发团队现在等待这个新管道已经很长时间了)。

我们的管道现在看起来像这样:

Build --- Unit Tests --- Integration Tests --- Functional Tests ---
                |                |                    |
              tool A            suite A        matrix-A-A-batch 0
              tool B            suite B        matrix-A-A-batch 1
              tool C                           matrix-A-A-batch 2
                                               matrix-A-A-batch 3
                                                     ....
                                              "Unable to display more"

您可以在此处找到我们 Jenkinsfile 的完整版本:https://github.com/willy-ahva/pim-community-dev/blob/086e4ed48ef1a3d880ca16b6f5572f350d26eb03/Jenkinsfile (它可能看起来很复杂,但基本上,真正的问题是“功能测试”阶段)

我的问题是:
  • 我使用并行的好方法吗?
  • 这只是 Jenkins/BlueOcean 问题,我应该为我链接的问题做出贡献吗? (如果是,怎么做?我根本不是 Java 开发人员)
  • 我应该尝试使用 MultiJob 并并行化作业而不是步骤吗?
  • 除了并行之外,还有其他工具可以使用吗? (某种 fork 或其他什么)?

  • 非常感谢你的帮助。我喜欢 Jenkins 使用 Pipeline 和 BlueOcean UI 所做的一切,我真的想让它在我们的团队中发挥作用。

    最佳答案

  • 这可能是执行并行任务的一种糟糕方式。相反,我会将每个并行映射条目视为一个 worker ,并将您的测试放入队列/堆栈/数据结构中。每个工作线程都可以根据需要从队列中弹出,然后您就不会坐在那里排队等待一百万个任务。您必须更加小心您的日志记录,以便很明显哪个测试失败了,但这不应该太难。
  • 这可能不是容易解决的问题,因为它与其他任何问题一样都是 UI 设计问题。不过我还是建议你戳一下!谁知道,也许一个解决方案会为您点击?
  • 可能不是。在我看来,这让这个事情变得更加困惑
  • Parallel 是您 fork 的选项。

  • 如果您真的想继续这样做,但又不想 UI 如此怪异,则可以停止将每个测试定义为一个阶段。当一个失败时,什么失败会不太清楚,但用户界面应该更快乐。

    关于Jenkins 流水线和大量的并行步骤,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43976022/

    相关文章:

    docker - 从 Jenkinsfile 启动时,Gradle docker 容器忽略缓存

    Jenkins 访问日志以调试问题

    Jenkins 离线安装插件

    java - Jenkins 可以在 slave 日志上自定义插件到 master 吗?

    python - 在 docker 和 Jenkins 中处理大型二进制文件 (3 GB)

    java - 使用 OpenJDK 将 Jenkins 节点/代理作为 Windows 服务运行

    jenkins - 无法打开 Blue Ocean 可视化管道编辑器

    Jenkins Blue Ocean 插件无法连接到 GitHub

    iOS Cocoapods 文件未找到错误

    jenkins - 如何在 Jenkins 中使用 Groovy 脚本设置 Subversion 工作区格式?