![](/img/trans.png)
[英]Jenkins path to git Windows master / Linux slave
[英]Jenkins Poll SCM (Git) on Windows master / Build on Linux slave
这是我的场景:
我已经配置了两个Git安装,如Jenkins路径中指示的那样, 用于git Windows master / Linux slave 。 Git安装设置如下:
WindowsGit
| 路径: C:\\Program Files\\Git\\bin\\git.exe
LinuxGit
| 路径: /usr/local/bin/git
因为我需要在linux slave上运行作业,我的作业git配置指向LinuxGit(Git可执行选项)。 工作运行良好,没有问题。 但是,当我尝试使用“Poll SCM”选项时,它会中断。 我相信这里的问题是因为Poll SCM在Windows Master上运行,而这项工作的Git信息指向LinuxGit。 Git Polling Log显示:
Caused by: java.io.IOException: Cannot run program "/usr/local/bin/git": CreateProcess error=2, The system cannot find the file specified
另一方面,如果我选择WindowsGit,Git Polling Log就可以了,但是作业本身显然会失败,因为它在Linux Slave上运行。
问题:有人可以考虑一种方法,我可以为源代码管理配置选择一个Git安装,为Poll SCM功能选择另一个吗?
根据要求,我发布了自己的一般想法的答案,在使用git时在Master Slaves上混合使用Windows / Linux。 这个解决方案甚至允许在多个Windows / Linux从属组合上运行相同的工作,也不会破坏Master轮询scm:
无论您使用Jenkins Master平台,都要将默认git安装配置为指向该平台的有效git。 例如,Windows的c:\\apps\\git\\bin\\git.exe
。 然后为每个节点配置自定义“ 工具位置 ”。 通过这种方式,主设备将能够轮询git以检查更改并在从设备上触发作业。 然后Slave将能够克隆git代码,因为它具有(Git)Default的自定义位置。 正确配置的步骤:
/usr/local/bin/git
) linux从属节点的节点配置应如下所示:
我相信额外的“git安装”更合适,正如@Jayan所提到的,当你需要多个git安装或者你需要为某些Jenkins作业运行特定版本的git时。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.