我在Windows Server 2012上运行Jenkins 2.25服务器。目前我们正在使用Maven Integration Plugin 2.12.1和Job DSL Plugin 1.57。
我已在我们的服务器上为大约200个现有作业编写了DSL脚本。
对于任何使用Maven的作业,无论是作为构建步骤还是作为实际的Maven,我都有一个非常令人沮丧的问题。当我运行生成的作业时,它们会失败并显示以下输出。
12:17:12 [ERROR] Failed to execute goal com.googlecode.maven-download- plugin:download-maven-plugin:1.3.0:wget (default) on project myprojecy: The parameters 'url' for goal com.googlecode.maven-download-plugin:download-maven-plugin:1.3.0:wget are missing or invalid -> [Help 1]
12:17:12 [ERROR]
12:17:12 [ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
12:17:12 [ERROR] Re-run Maven using the -X switch to enable full debug logging.
12:17:12 [ERROR]
12:17:12 [ERROR] For more information about the errors and possible solutions, please read the following articles:
12:17:12 [ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/PluginParameterException
最初我们认为我们发现这个问题是因为我们错过了XML片段,甚至认为这些设置看起来就像它们应该在UI中一样。
<settings class="jenkins.mvn.DefaultSettingsProvider"/>
<globalSettings class="jenkins.mvn.DefaultGlobalSettingsProvider"/>
<injectBuildVariables>false</injectBuildVariables>
因此将其添加到脚本中:
configure { node ->
node / settings (class: 'jenkins.mvn.DefaultSettingsProvider') {
}
node / globalSettings (class: 'jenkins.mvn.DefaultGlobalSettingsProvider') {
}
node / injectBuildVariables ('false') {
}
}
但是当我尝试运行它们时,作业仍然失败,即使XML现在包含了预期的片段。
现在我能解决的两件非常离奇的事情显而易见。首先,在作业失败后,如果我手动选择&#34;配置&#34;为了工作,然后保存它(即不做任何实际的改变),工作永远运行良好(直到种子工作我们运行然后它再次失败)。
其次,在运行种子作业后的作业配置历史记录中,我看到种子作业在系统用户下运行时所做的更改。但是,在几秒钟内,每次都会在我的用户名下记录另一个配置更改,尽管事实上我没有对作业配置进行任何更改 - 顺便说一句,这与我保存作业无关,它立即发生。
我应该补充一点,进一步的检查告诉我,Maven有一些默认设置没有应用于我生成的DSL作业。将-X开关添加到Maven目标时,我可以看到有关这些作业失败的更多信息。输出是:
15:06:31 [DEBUG] Goal: com.googlecode.maven-download-plugin:download-maven-plugin:1.3.0:wget (default)
15:06:31 [DEBUG] Style: Regular
15:06:31 [DEBUG] Configuration: <?xml version="1.0" encoding="UTF-8"?>
15:06:31 <configuration>
15:06:31 <cacheDirectory>${download.cache.directory}</cacheDirectory>
15:06:31 <checkSignature default-value="false">${checkSignature}</checkSignature>
15:06:31 <failOnError default-value="true"/>
15:06:31 <outputDirectory default-value="${project.build.directory}">D:\data\jenkins\workspace\project\target</outputDirectory>
15:06:31 <outputFileName>${jarsigner.keystore.filename}</outputFileName>
15:06:31 <overwrite>${download.overwrite}</overwrite>
15:06:31 <readTimeOut default-value="0"/>
15:06:31 <retries default-value="2"/>
15:06:31 <session>${session}</session>
15:06:31 <skip default-value="false">${download.plugin.skip}</skip>
15:06:31 <skipCache default-value="false"/>
15:06:31 <unpack default-value="false">false</unpack>
15:06:31 <url>${jarsigner.keystore.url}</url>
15:06:31 </configuration>
在成功运行作业(发布虚假配置更改)的情况下,其中一些字段已满,例如密钥库的URL。这显然是个问题,但我不知道该怎么做。我可以告诉你这应该通过在groovy中包含上面的配置块来解决,但不知何故我的工作缺少这个(但他们在再次保存作业后没有更改)。
谁能看到我在这里做错了什么?
答案 0 :(得分:2)
问题是XML中的代码是自动生成的:
<jvmOptions></jvmOptions>
似乎尽管是空的,但这会覆盖任何默认的Maven选项,但是当作业再次保存时,它会被取出,因为它是空的。通过将其添加到groovy脚本解决:
configure({
it.remove(it / 'jvmOptions')
})
这似乎是DSL中的一个错误,但令我惊讶的是我的同事和我一直无法找到任何提及。无论如何,以上解决了这个问题。