- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在与 Jenkins 进行并行测试。
我设置它的方式是我有一个并行执行其他三个作业的构建流程作业。其他三个作业连接到单独的测试 XML 文件。
当我最初开始这个时,我遇到了一个问题,即只有两个作业会同时执行,而第三个作业只会在其他作业之一完成后才执行。
我发现这是由于我的 Jenkins 将执行者的数量设置为 2
,现在设置为 5
.
但是,作为一个有趣的问题,只是为了 future 的规划,Jenkins 对您可以拥有的 executors 数量有上限吗?或者是否有您不应超过的推荐数量?还是仅取决于您运行它的环境?
如果有上限/建议数量不超过?我认为解决这个问题的最佳方法是使用主/从方案并将工作负载分布在多个 VM 上。
例如,如果我将它设置为 6 个执行程序,这是否意味着我将在每个 VM 上有 6 个执行程序?或者在 VM 之间共享 6 个执行程序?
最佳答案
这实际上取决于您的环境以及分配给该 Jenkins 实例的资源量。我认为 Jenkins 允许的执行人数量没有任何限制。我们目前使用 20 个执行器运行一个 Jenkins 实例,没有任何问题。当然,根据您的构建管道和提交模式,您可能会发现您设置的执行程序数量过多。您只需要注意是否在任何给定时间实际使用了所有执行程序。
如果您发现您的 Jenkins 实例已接近资源上限,并且无法增加资源限制,那么您可能想要开始使用从属设备。
我们关注资源使用情况的一种方式是通过 Monitoring plugin .
***编辑:
由于我们的管道实际在做什么,我们最近不得不重新评估我们的执行器与处理器的比率。您确实需要确定管道/作业的 CPU 限制。这将不可避免地因用例而异。
在我们的例子中,我们的管道非常受 CPU 限制,并且随着我们优化系统、引入并行处理等而变得更多。我们最终每个 cpu 核心有一个执行程序,还有一些额外的“管理”执行程序来运行快速/轻量级任务.
我们目前在具有 20 个内核的单台机器上运行 jenkins,但同样,这将根据您的用例而有所不同。我们必须进行大量计算,才能根据构建频率和目标构建时间确定需要多少个执行器/cpu 内核。当我们最终不得不提高处理能力时,我们最终会使用从属设备在多台机器之间分配作业。
另一个注意事项:您还需要考虑可用内存,因为增加执行程序的数量会增加消耗的内存量。我们有一个案例,我们有足够的处理能力但没有足够的内存,这导致 Jenkins 的进程由于 OutOfMemory 错误而崩溃。
关于jenkins - 您可以拥有多少个 Jenkins Executor?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38094132/
我想创建一个 Jenkins 工作来启动其他 Jenkins 工作。这很容易,因为 Jenkins 模板项目插件允许我们创建“使用另一个项目的构建器”类型的构建步骤。然而,让我的情况更难的是我必须在其
我有一个简单的Windows批处理命令(robocopy),该命令返回零错误,但在Jenkins中始终被标记为失败。我想知道为什么? D:\ Jenkins \ jobs \ Jenkins Conf
我有两个 Jenkins 工作 - Jenkins Job1 和 Jenkins Job2。 我有多个应用程序并使用相同的 Jenkins 来构建应用程序。如果相同的应用程序在 Jenkins 中运行
我找不到这两者之间的区别。这些是相同的还是不同的。 最佳答案 第一个区别是支持(正如其他人所提到的)。 CloudBees 提供企业级支持以及经过全面审查和测试的 Jenkins 版本,该版本将在各种
是否可以指定在多次触发作业(A)的情况下,将先前的作业从队列中删除,并且如果有足够的可用插槽,则仅将最新的作业留在队列中或启动? 提前致谢! 最佳答案 您可以使用通过Groovy Script Plu
我有2位Jenkins主持人,并且希望First Jenkins在第一个结果的基础上基于“SUCCESS”触发远程Jenkins上的工作。 我看过各种插件,但它们似乎都表明一个Jenkins主机,可以
我的 jenkinsfile 有几个参数,每次我更新参数(例如删除或添加新输入)并将更改提交到我的 SCM 时,我没有在 jenkins 中看到相应更新的作业输入屏幕,我必须运行执行,取消它,然后查看
有没有办法在构建完成后触发相同的工作。我有一项工作需要运行,直到我手动中止它。有没有办法做到这一点? 最佳答案 最简单的方法是添加一个构建相同项目的后期构建步骤。将“构建后操作”-“构建其他项目”-“
我在 Linux 家中的特定用户下有工作/.jenkins 文件夹。我想与另一个用户一起启动 Jenkins,但重新使用另一个用户的 .jenkins 文件夹。我怎样才能做到这一点? Jenkins
我是 Jenkins 的新手,我不确定这是否可行,但我想设置一个 Web 界面,人们可以在其中单击“开始作业”,这将告诉 Jenkins 开始特定的构建作业。 Jenkins 是否有允许此类操作的网络
如何获取 Jenkins 凭证变量,即“mysqlpassword”,可供 Jenkins 声明性管道的所有阶段访问? 下面的代码片段工作正常并打印我的凭据。 node { stage('Gett
如何获取 Jenkins 凭证变量,即“mysqlpassword”,可供 Jenkins 声明性管道的所有阶段访问? 下面的代码片段工作正常并打印我的凭据。 node { stage('Gett
如何将构建参数从一个项目传递到另一个项目? 我们在 Jenkins 用户界面中是否有任何配置,可以在完成一个构建项目后将构建参数传递给另一个项目? 我能够触发另一个项目,但无法传递构建参数。我们是否有
我正在 Jenkins 中构建一个项目,并希望在它之后立即启动测试,请稍候 直到测试完成,然后运行另一个作业来分析结果。测试系统是一个封闭的系统(我不能修改它)所以为了检查测试是否完成我需要每 X 秒
我创建了一个测试 jenkins 作业管道。此作业具有字符串参数 - 'testVar' Jenkins文件代码: println("env.TESTVAR=" + env.TESTVAR) prin
我的 Jenkins 工作“构建”配置有 3 执行 shell - 构建任务 2 构建后操作 有没有办法获取每个构建任务和构建后操作的运行时间? 最佳答案 不直接,这就是为什么: 我使用 a Jenk
是否有任何适用于 Jenkins 的插件可以为 Jenkins 提供键值存储选项?功能接近的插件是凭据插件。目标是拥有一个存储全局配置参数的插件,并且此参数可用于 Jenkins 作业。 最佳答案 转
默认情况下,Jenkins 是否会保留每个构建中生成的所有构建和工件。或者它会在一段时间后删除它们。我知道我可以配置“丢弃旧版本”选项,但我想知道 Jenkins 的默认行为。 最佳答案 默认是保留所
Jenkins 构建中的每个文件参数“帮助文本”, Accepts a file submission from a browser as a build parameter. The uploade
情况:我在我的虚拟服务器上安装了 Jenkins 并设置了一个“自由式管道”。我通过 webhook push 将它连接到我的 github,它可以工作(当我推送到存储库时,在 jenkins 中启动
我是一名优秀的程序员,十分优秀!