apache-tomcat-9.0.19 配置unpackWARs="false"导致spring注入失败问题记录

运行环境:

OS:window7旗舰版 Service Pack1

server : apache-tomcat-9.0.19

JDK:1.8.0_221  Java HotSpot(TM) 64-Bit Server VM (build 25.221-b11, mixed mode) 

 

问题描述:

在myeclipse使用maven-3.6.3将项目打成war后放在tomcat下,双击startup.bat启动,发现加载到war包时非常缓慢,最后spring报错说有一个类的属性注入失败且无法找到对应的类,报错截图如下:

Spring无法找到LdapService,随后怀疑是maven打包时可能没有将这个类加入,解压war却发现有这个类,截图下:

随后解决问题的过程可以说是一波三折,重新打包|发现还是报错--->将war包发布到另外一个tomcat-9.0.19下发现竟然启动成功--->意识到是tomcat的问题,就去仔细查看日志--->凡是警告或者有稍微不正常的日志就将日志信息百度,最终找到一段日志描述,描述如下:(xxx是war包的文件名)

28-Feb-2020 13:54:04.461 警告 [Catalina-utility-1] org.apache.catalina.startup.HostConfig.deployWARs 

The directory [D:\ProgramFile\Developer\apache-tomcat-9.0.19.xftx\apache-tomcat-9.0.19\webapps\xxx] 

will be ignored because the WAR [D:\ProgramFile\Developer\apache-tomcat-9.0.19.xftx\apache-tomcat-9.0.19\webapps\xxx.war] takes priority and unpackWARs is false

其中unpackWARs是tomcat/config/server.xml 中<Host>标签里面的一个属性,unpackWARs="true"则tomcat会自动将WAR文件解压,否则不解压,直接从WAR文件中运行应用程序,自己tomcat配置的是false,即直接从war文件运行应用导致无法正常注入bean,spring报错,修改为unpackWARs="true"正常启动且tomcat下webapps中出现一个和war文件名一样的目录,但是至于为什么从war中运行应用程序就会导致spring无法正常注入的原因还是不清楚,也不知道其它的tomcat版本是否会出现相同问题本人用的是apache-tomcat-9.019

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值