运行环境:
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