Jas*_*ger 12 hudson reboot slave jenkins
我有一个Jenkins(Hudson)服务器设置,可以在各种从机上运行测试.我想要做的是重新配置从属设备(使用远程API),重新启动从属设备以使其更改生效,然后继续测试的其余部分.到目前为止我遇到了两个障碍:
这可能吗?到目前为止,我还没有找到使用Jenkins或其任何插件的方法.
编辑 - 进一步解释 我真的非常喜欢Jenkins奴隶架构.结合已有的插件,它可以很容易地将作业送到从站,运行,并且结果被撤回.并且能够选择任何匹配的从站允许自动作业/测试分发.
在我们的情况下,我们使用虚拟化(VMware)从机.编写一个脚本可以很容易地使Jenkins在需要在从属设备上运行时使用VMware PowerCLI来启动VM,然后将作业发送给它并将结果拉回来.都好.
除了每个测试的部分设置是以某种方式稍微重新配置虚拟机.禁用UAC,以其他用户身份登录,安装不同的驱动程序等 - 每个更改都要求在更改生效之前重新启动测试VM /从服务器.虽然我可以编写从属按需脚本(启动方法=通过在主服务器上执行命令启动从服务器)来处理此重新配置并重新启动,但必须在作业运行之前完成.这就是问题发生的地方 - 我无法提前配置从站,因为配置更改的类型取决于正在运行的作业,这仅在从站启动后发生.
可能的解决方案
1)在单个VM上使用多个从属实例.这不起作用 - 几个配置是互斥的,但Jenkins不知道.因此,它会尝试为一个作业启动一个从站配置,为另一个作业启动另一个从站 - 并且两个从站都将在同一个VM上.锁定作业不会阻止这种情况,因为从属启动不是工作的一部分.
2)(Optimal)一个构建步骤,允许作业知道它的从属连接可能被中断.构建步骤可能必须包含一些选项,以便Jenkins知道如何重新连接从属设备(将自动重新连接,Jenkins是否必须运行脚本,简单的SSH就足够了).构建步骤将处理从站的断开连接,忽略通常作业失败的断开连接,然后执行重新连接.从站恢复运行后,可以进行下一个构建步骤.如果从站在一定时间内无法重新连接,则可能是作业失败的超时.
**当前的解决方案** - 不是最优的
现在,我不能使用Jenkins的从属功能.相反,我使用一系列构建步骤 - 在master上运行 - 使用Windows和PowerShell脚本启动VM,进行配置并重新启动它.VM上运行了SSH服务器,我使用它将测试文件上传到测试VM,然后远程执行它们.然后将结果下载回Jenkins以便按作业处理.这个解决方案是功能性的 - 但比典型的Jenkins从属方法要多得多.此外,脚本针对单个VM; 我不能轻易使用一群奴隶.
不确定这是否适合您,但您可以尝试以编程方式使Jenkins代理节点告知主节点它处于脱机状态.
我有一种情况,我需要做一个执行这些步骤的Jenkins工作(所有在主节点上运行时):
我使用curl POST请求执行代理断开连接步骤,但可能有更简洁的方法:
curl -d "offlineMessage=&json=%7B%22offlineMessage%22%3A+%22%22%7D&Submit=Yes" http://JENKINS_HOST/computer/THE_NODE_TO_DISCONNECT/doDisconnect
Run Code Online (Sandbox Code Playgroud)
然后,当我启动代理节点时,代理启动并自动连接,并且主通知代理重新联机(然后将其发送作业).
我还能够使用此命令打开和关闭节点的可用性(使用'toggleOffline'而不是'doDisconnect'):
curl -d "offlineMessage=back_in_a_moment&json=%7B%22offlineMessage%22%3A+%22back_in_a_moment%22%7D&Submit=Mark+this+node+temporarily+offline" http://JENKINS_HOST/computer/NODE_TO_DISCONNECT/toggleOffline
Run Code Online (Sandbox Code Playgroud)
(再次运行相同的命令会使节点状态恢复正常.)
以上内容可能不适用于您,因为您似乎想要从代理节点上运行的一个jenkins作业执行所有操作.而且我不确定如果代理节点在运行作业的过程中断开连接或标记为脱机,会发生什么.:)
不过,您可能会在这个远程访问API文档中稍微探讨一下,看看这种方法还有什么可能.
好简单。您创建一个在 Master 上运行的主作业,从主作业中您将客户端作业称为构建步骤(这是一种新的构建步骤,我喜欢它)。您需要检查主作业是否应等待客户端作业完成。然后,您可以运行脚本来重新配置客户端并在客户端上运行第二个测试。
更好的策略是在从机上运行两个节点。您需要在 Jenkins 中配置两个节点。我在 UNIX 从机上成功地使用了该策略。原因是我需要设置不同的环境变量,并且我不想将其推入工作中。我使用 ssh 客户端,所以我不知道是否可以使用不同的客户端类型。您可能能够同时运行这两个测试,或者链接作业或使用上面提到的主策略。
| 归档时间: |
|
| 查看次数: |
20278 次 |
| 最近记录: |