java - 使用 Maven 在 Tomcat 中动态运行 WAR,如何添加类路径条目以便只有 Tomcat 可以看到它们?

标签 java tomcat maven-2

场景是这样的:我有一个 web 应用程序,我想使用 tomcat-maven-plugin 的 tomcat:run goal 动态运行它。 。问题是我有大量的类路径资源,需要区分打包的工件和本地工作站运行的工件。

失败的尝试:

1.) 我的第一次尝试是使用 builder-helper-maven-plugin,但它不起作用,因为目标配置文件将(不一致!)进入打包的 WAR 存档中。

<plugin>    
 <groupId>org.codehaus.mojo</groupId>
 <artifactId>build-helper-maven-plugin</artifactId>
 <version>1.3</version>
 <executions>

  <execution>     
   <id>add-resource</id>
   <phase>generate-resources</phase>
   <goals>
    <goal>add-resource</goal>
   </goals>
   <configuration>
    <resources>
     <resource>
      <directory>${basedir}/src/main/resources-env/${testEnv}</directory>
      <targetPath>${basedir}/target/classes</targetPath>
     </resource>
    </resources>
   </configuration>
  </execution>
 </executions>
</plugin>

2.) 我的第二次尝试是将文件夹添加到 -Djava.ext.dirs 中(因为要部署的文件也不存在于 Tomcat 的类路径中),但它没有效果(实际上我怀疑此 systemProperties 元素配置错误或根本无法工作)。请参阅:

<plugin>
 <groupId>org.codehaus.mojo</groupId>
 <artifactId>tomcat-maven-plugin</artifactId>
 <version>1.0-beta-1</version>
 <configuration>
  <tomcatWebXml>${basedir}/src/main/mock/web.xml</tomcatWebXml>

  <systemProperties>
   <property>
    <name>java.ext.dirs</name>
    <value>${basedir}/src/main/resources-env/${testEnv}</value>
   </property>      
  </systemProperties>      
  <path>/licensing</path>
 </configuration>
</plugin>

我不确定接下来要尝试什么。问题的核心似乎是这个插件中缺少像 Surefire 的 <additionalClasspathElement> 这样的东西。元素。

下一步是创建自定义 catalina.properties 并将其添加到 <configurationDir> ?如果是这样,catalina.properties 需要是什么样子?

编辑:以下是更详尽的解释

我知道这个问题读起来有些含糊,所以我会尝试详细说明一下。

我的 POM 使用 WAR 插件的 webResources 功能来复制一些特定于环境的配置文件,而不使用配置文件来完成此操作,方法是复制名为 /src/main/resources-env/${env} 的资源。像这样:

...
<plugin>    
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-war-plugin</artifactId>
        ...
    <configuration>
            ...
        <webResources>
            <!-- Copy Environment-specific resources to classes -->
            <resource>
                <directory>${basedir}/src/main/resources-env/${env}</directory>
                <targetPath>WEB-INF/classes</targetPath>
            </resource>
        </webResources>
    </configuration>
</plugin>

这会将(默认,DEV)环境资源复制到包中,并且当前工作正常。另请注意,b/c 这些是作为包装的一部分出现的,tomcat:run他们永远不会知道目标(这是期望的,因为环境不同)。

所以问题是这样的:当动态tomcat:run时执行时,应用程序将失败,因为其类路径(它查看 target/classes )将缺少所需的本地工作站环境配置文件。我需要做的就是将这些内容放在 tomcat 的路径上,但希望在不向命令行添加任何内容的情况下这样做,并且如果有人跟进 mvn package 的话,绝对不会破坏构建的完整性。并且没有clean首先。

我希望这更清楚。

最佳答案

我可能遗漏了一些东西,但为什么不在配置文件中声明所需的依赖项并在运行 Tomcat 时使用此配置文件?我不明白为什么您需要将这些资源放在 Tomcat 的类路径级别。

更新:我正在编辑我的答案,以涵盖OP本身回答我上面的问题的评论。

You're correct, the files really need to be in the webapp classpath, not tomcat's. So how could I make a profile that activate automatically for tomcat:run but without additional cmd line args?

我不知道如何在不将配置文件声明为 <activeByDefault> 的情况下执行此操作或将其列在 <activeProfiles> 下(但这不是我的想法,我宁愿使用属性激活并调用类似 mvn tomcat:run -Denv=test 的东西,不确定为什么这是一个问题)。

And how should I "declare the dependencies" in the profile while ensuring that subsequent invocations never let them into the package WAR via a vanilla mvn package

如果前面提到的配置文件默认处于 Activity 状态,那么如果您不需要它,则需要通过调用类似 mvn package -P !profile-1 来排除它。 。无法为某个特定目标神奇地停用配置文件(至少据我所知)。

实际上,我的理解是,这里确实有两个不同的上下文:“测试”上下文(您希望在 WAR 中包含更多内容)和“正常”上下文(您不希望这些内容出现在其中)被包括在内)。老实说,我不知道如何在不指定任何附加参数的情况下区分这两种情况(根据上下文激活配置文件或停用它)。你必须有正当的理由,但正如我所说,我真的不明白为什么这是一个问题。因此,也许配置文件不能解决您的情况。但我真的很想了解为什么,因为这似乎是配置文件的典型用例:)

UPDATE2:阅读了您对其他答案的评论和更新后,我意识到我最初的理解是错误的(我虽然您在谈论 Maven 意义上的依赖关系)。但是,我仍然认为配置文件可以帮助您,例如自定义 <resources>就像这个blog post (这只是一种方法,在路径中使用像 src/main/resources/${env} 这样的属性是另一种方法)。但这并不能解决您的所有问题(例如不指定其他命令行参数或自动清理目标目录)。我对此没有任何解决方案。

关于java - 使用 Maven 在 Tomcat 中动态运行 WAR,如何添加类路径条目以便只有 Tomcat 可以看到它们?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1923302/

相关文章:

java - JPQL 中带有 IN 运算符的枚举列表

macos - Maven 的 settings.xml 在 Mac OS 上位于哪里?

java - ServletServerCache 和 ClassNotFoundException 之谜

java - XStream 避免收集 xml 元素

java - TopCoder 使用离线可视化工具进行割草挑战

java - Tomcat的 "Catalina service"和 "Servlet Engine"之间的区别

tomcat - Jersey 如何在 Tomcat 服务器上运行?

Java 作为外部组件使用 Swing : main thread never exits

maven-2 - Maven 尝试下载依赖项,尽管它存在于本地存储库中

java - 如何将 Tiles 3 与 Struts2 正确集成?