3

我正在浏览jenkins-the-definitive-guide。我已经使用 Windows 安装程序在 Windows 7 64 位上安装了 Jenkins。我已经配置了构建并设置 Jenkins 以在第一次构建时自动安装 JDK 7u3。当构建开始时,我在控制台日志中看到了这一点:

Started by user anonymous
Building in workspace C:\Program Files (x86)\Jenkins\workspace\gameoflife-default
Installing C:\Program Files (x86)\Jenkins\tools\JDK_7u3\jdk.exe 
[JDK_7u3] $ "C:\Program Files (x86)\Jenkins\tools\JDK_7u3\jdk.exe" /s /v /qn /L '\"C:\Program Files (x86)\Jenkins\tools\JDK_7u3\jdk.exe.install.log\"' REBOOT=ReallySuppress 'INSTALLDIR=\"C:\Program Files (x86)\Jenkins\tools\JDK_7u3\"'

它永远不会超越这一点。

我尝试过: - 确保 exe 未被阻止 - 确保服务帐户具有管理员权限 - 尝试安装其他 JDK。

有什么想法吗?

4

1 回答 1

6

JDK7的JDK自动安装出现错误,似乎:
https ://issues.jenkins-ci.org/browse/JENKINS-5408

如果您尝试在命令行上运行该命令,则会出现msiexec对话框,这意味着参数不正确。由于我也遇到了这个问题,我去看看詹金斯实际通过了什么。它确实(在我们的例子中):

c:\jenkins\tools\JDK\jdk-1.7.0_06\jdk.exe /s /v /qn /L \"c:\jenkins\tools\JDK\jdk-1.7.0_06\jdk.exe.install.log\" REBOOT=ReallySuppress INSTALLDIR=\"c:\jenkins\tools\JDK\jdk-1.7.0_06\"

转义引号是旧式msiexec安装的保留,其中所有之后的内容/v都必须用单引号引起来,因为它们都被传递给其他东西。单引号转义已被删除,但实际语法也不再正确(安装程序已更改,选项也已更改)。问题是在INSTALLDIR变量中进行的引号转义。如果您删除它,它将进行安装(您可能仍然有一个 msiexec 进程挂起)。例子:

c:\jenkins\tools\JDK\jdk-1.7.0_06\jdk.exe /s /L \"c:\jenkins\tools\JDK\jdk-1.7.0_06\jdk.exe.install.log\" REBOOT=ReallySuppress INSTALLDIR=\"c:\jenkins\tools\JDK\jdk-1.7.0_06\"

您可能可以走得更远,使用/norestart而不是设置 reboot 属性,具体取决于它是否受到尊重。

我提出的所有这些建议仍然没有解决实际问题,即“如何正确自动安装 JDK7”。如果您遇到此问题,我不知道您是否可以不手动完成安装然后在主配置中关闭自动安装。对我来说,清理缓存文件似乎没有帮助。

于 2012-09-18T19:11:49.440 回答