我对 Jenkins 很熟悉,但对 Maven 很陌生,我正试图弄清楚如何阻止我们在 Jenkins 中的 Maven 作业在ApplicationContext.xml
文件中扩展环境变量。
在我们的ApplicationContext.xml
文件中,我们引用了${DeployMode}
Tomcat 在加载/运行时扩展的环境变量(我们创建的):
<!-- SPRING CONTEXT static accessor -->
<beans:bean id="contextApplicationContextProvider"
class="com.dartneuroscience.compserv.rest.appcontext.AppContextProvider">
<beans:constructor-arg>
<beans:value>${DeployMode}</beans:value>
</beans:constructor-arg>
</beans:bean>
<beans:bean id="placeholderConfig"
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<beans:property name="location"
value="/WEB-INF/App_${DeployMode}.properties" />
</beans:bean>
问题是,在 Jenkins 运行的 Maven 构建中,WEB-INF/ApplicationContext.xml
如果在构建机器上设置了环境变量,则构建看起来像这样(在本例中假设为“Prod”):
<!-- SPRING CONTEXT static accessor -->
<beans:bean id="contextApplicationContextProvider"
class="com.dartneuroscience.compserv.rest.appcontext.AppContextProvider">
<beans:constructor-arg>
<beans:value>Prod</beans:value> <!-- Expanded env. var -->
</beans:constructor-arg>
</beans:bean>
<beans:bean id="placeholderConfig"
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<beans:property name="location"
value="/WEB-INF/App_Prod.properties" /> <!-- Expanded env. var -->
</beans:bean>
因此,该值现在被“硬编码”到 WAR 中,即使目标 Web 服务器将其DeployMode
环境变量设置为其他值,例如“Staging”,它也始终表现得像“Prod”。
当我在同一个构建服务器上手动运行 Maven 时不会发生这种情况——它只会在 Jenkins 构建作业时发生。
有没有我可以传递给 Jenkins 来阻止这种行为的设置?
在运行作业时,我已经查看了所有环境变量的 EnvInject 插件等选项UNSET
,但我真的对这种行为感到困惑,并想深入了解它。
谢谢你。
更新 1
我在顶级 POM 中找到了以下资源过滤块,并添加了该<excludes/>
块以跳过我们的AppContext.xml
文件:
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<version>2.1.1</version>
<configuration>
<webResources>
<webResource>
<directory>${basedir}/src/main/webapp/WEB-INF</directory>
<includes>
<include>*.xml</include>
</includes>
<excludes>
<exclude>*AppContext.xml</exclude>
</excludes>
<targetPath>WEB-INF</targetPath>
<filtering>true</filtering>
</webResource>
</webResources>
但这仍然没有回答为什么在 Jenkins 运行时环境变量被添加到属性列表中,而在从命令行运行时被忽略;虽然几年前我确实发现了这个哈德逊问题:从哈德逊运行时资源过滤失败
此外,EnvInjectPlugin 执行它所宣传的内容,但在至少删除 PATH 变量时,构建中断,因为 maven 找不到该ls
命令。
更新 2
将 Jenkins 中的工作从“Maven 2/3 项目”更改为“自由式软件项目”并使用Invoke top-level Maven targets
构建步骤产生所需的结果,而无需修改 POM。