java - 如何使用 maven-tomcat7-plugin 在 Tomcat 上正确热部署/重新部署战争?
问题描述
我知道有很多线程在谈论它,但我暴露了一个我无法在他们的帮助下解决的情况。我希望我的问题,如果将来它得到解决,我可以帮助更多的人。
我正在尝试在Tomcat中进行一次战争的热部署,我发现自己有以下四种情况:
情况1
从项目文件夹执行的部署命令:
mvn clean install org.apache.tomcat.maven:tomcat7-maven-plugin:2.2:deploy -P PROFILE_ONE,PROFILE_TWO -Dmaven.skip.test=true -DskipTests=true -Dmaven.javadoc.skip=true -Dsource.skip=true -Dproject.build.sourceEncoding=UTF-8 -Dcobertura.skip=true -Dmaven.skip.test=true -DskipTests=true -Dmaven.javadoc.skip=true -Dsource.skip=true -Dproject.reporting.outputEncoding=UTF-8 -Dmaven.tomcat.path=/MY_PATH -Dmaven.tomcat.url=http://localhost:8081/manager/text -Dmaven.tomcat.server=TomcatServer -Dtomcat.password=TOMCAT_USER -Dtomcat.username=TOMCAT_PASSWORD
和 apache-tomcat-7.0.91\conf\context.xml 具有以下属性:
<Context antiResourceLocking="true" antiJARLocking="true">
案例 1 结果
部署似乎工作正常,但是当我进入应用程序时出现以下错误:
找不到此页面 (localhost) 找不到地址http://localhost:8081/MY_PATH/#/PATH的网页。HTTP 错误 404
案例2
从项目文件夹和 apache-tomcat-7.0.91\conf\context.xml 执行的案例 1 的相同命令没有防锁定属性:
<Context>
案例 2 结果
部署和应用程序正常工作,但是当我尝试重新部署时,使用相同的命令并添加属性-Dmaven.tomcat.update=true
无法正常工作,因为有几个 jar 被阻止并且 tomcat 无法删除它们。(这就是为什么在其他情况下我添加防锁定属性的原因)
案例3
从项目文件夹和 apache-tomcat-7.0.91\conf\context.xml 执行的案例 1 的相同命令具有以下属性:
<Context antiJARLocking="true">
案例 3 结果
等于案例2的结果。
案例4
从项目文件夹和 apache-tomcat-7.0.91\conf\context.xml 执行的案例 1 的相同命令具有以下属性:
<Context antiResourceLocking="true">
案例 4 结果
等于案例1的结果。
结案
如您所见,我的目标是进行第一次部署,然后重新部署相同的应用程序(在项目文件夹中进行更改)。我找到的所有信息都在谈论防锁定属性,但正如我上面所说,当我将它们放在 context.xml 上时,应用程序似乎无法正常工作。重要的是,由于项目需要,我不能更改战争的名称。
编辑 1
案例5
我也尝试过使用以下命令:
mvn clean install -U -P PROFILE_ONE,PROFILE_TWO -Dmaven.skip.test=true -DskipTests=true -Dmaven.javadoc.skip=true -Dsource.skip=true -Dproject.build.sourceEncoding=UTF-8 -Dcobertura.skip=true -Dmaven.skip.test=true -DskipTests=true -Dmaven.javadoc.skip=true -Dsource.skip=true -Dproject.reporting.outputEncoding=UTF-8 org.apache.tomcat.maven:tomcat7-maven-plugin:2.2:redeploy-only -Dmaven.tomcat.path=/MY_PATH -Dmaven.tomcat.url=http://localhost:8081/manager/text -Dmaven.tomcat.server=TomcatServer -Dtomcat.password=admin -Dtomcat.username=admin
和 apache-tomcat-7.0.91\conf\context.xml 具有以下属性:
<Context antiResourceLocking="true">
案例 5 结果 KO
等于案例1的结果。
为什么antiResourceLocking="true"
会导致结果 1 错误?
解决方案
根据Tomcat ,您不应该同时使用antiResourceLocking
和功能:antiJARLocking
antiJARLocking 是 antiResourceLocking 的子集,因此,为防止重复工作和可能出现的问题,任何时候都应将这些属性中的一个设置为 true。
还有关于使用antiResourceLocking 的具体警告
请注意,将此设置为 true 会产生一些副作用,包括在正在运行的服务器中禁用 JSP 重新加载:请参阅 Bugzilla 37668。
请注意,在主机的 appBase 之外的应用程序(默认为 webapps 目录)中将此标志设置为 true 将导致应用程序在 Tomcat 关闭时被删除。您可能不想这样做,所以在为它的主机设置 appBase 之外的 web 应用程序上设置 antiResourceLocking=true 之前要三思而后行。
推荐阅读
- php - Check for Product Category in cart items with WooCommerce
- node.js - GCP Cloud Function 从 Cloud Storage 读取文件
- reactjs - google-map-react 标记未显示
- java - 我们如何从 Java 启动一个 mockserver 来接收传入的流量?
- azure - 通过 Azure AD SCIM 管理 SaaS 用户和组
- python - 如何从价值 $1,632.50 (BigQuery) 中仅提取数字
- google-oauth - Google API PHP Authentication Invalid Token Format(问题和答案)
- java - Eclipse、JSF、Java 中的 Crud 实现
- java - 更新多个实体的 Spring Data JPA 问题
- unity3d - 视频播放中断最后几秒