本文主要是介绍Tomcat 实例化 Web 项目两次导致 Log4j 日志打印到前一天解决办法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
最近查看服务器 Log4j 日志 , 发现当天的日志少了很多 , 并且很多都打印到了前一天的文件里面 , 查了下发现可能是 Tomcat 启动时项目实例化两次的问题 , 然后我看了下 Tomcat 的 conf/server.xml
文件
<Host name="localhost"><Valve className="org.apache.catalina.valves.AccessLogValve" directory="/usr/local/logs/om"prefix="biom-access.log." suffix="" pattern="%{X-Real-IP}i %l %u %t "%r" %s %T" /><Context docBase="${catalina.home}/webapps/om" path="/om" reloadable="false"/>
</Host>
这里面配置了一个直接到 webapps/om
的 Context , webapps 文件夹下面确实有这个项目 , 问题就出在这里
Tomcat 默认启动的时候会实例化 webapps 下面的项目 , Context 里面又实例化了一次 , 就相当于实例化了两次
解决办法是去掉 conf/server.xml
文件的 Context , 或者不要把项目放置在 webapps 文件夹里面就可以了
作者 Github : tojohnonly , 博客 : EnskDeCode
这篇关于Tomcat 实例化 Web 项目两次导致 Log4j 日志打印到前一天解决办法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!