最近使用log4j的过程中,一直找不到输出的日志,连控制台的也没有,感觉很奇怪。在网上搜了一下,log4j可以开启调试方式。
可以通过在java命令中添加-Dlog4j.debug
虚拟机参数来打印log4j的调试信息。
tomcat的话在Window->Perferences->MyEclipse->Servers->Tomcat 8.x->JDK。
注意不是tomcat下的Optional Program Arguments,之前就是放到这里了发现一直不好使。
打印出来的结果显示log4j先查找的xml文件,找不到才会尝试加载properties文件,结果在一个jar包里找到了log4j.xml,就不再加载我们项目下面的配置文件了。
在web.xml中添加以下配置:
<context-param> <param-name>log4jConfigLocation</param-name> <param-value>WEB-INF/classes/log4j.properties</param-value> </context-param> <listener> <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class> </listener>
这样在启动的时候Spring会到classpath下加载我们项目里的log4j.propertes文件,实现将jar包中的配置文件过滤掉的功能了。
原文:http://www.cnblogs.com/jiang-s/p/7894520.html