3

我对 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。

4

1 回答 1

2

Jenkins 可能会以某种方式启用资源过滤。您有很多配置过滤的选择。您可以完全禁用它,将过滤限制为具有某些扩展名的文件,告诉它不要在过滤器中包含构建属性,或者选择不同的分隔符来完全过滤。请参阅资源:资源文档资源过滤概念的描述

于 2012-09-21T14:30:41.500 回答