Spring提供了一个Log4jConfigListener,可以在web.xml中配置来指定位置加载log4j配置文件和log日志文件的路径。
原理即为这个listener在启动时将web目录的路径通过System.setProperty("webapp.root","")方法,为当前JVM SET了一个名为webapp.root的系统变量,这样可以通过在log4j.properties中l设置相对文件路径,如:log4j.appender.logfile.File=${webapp.root}/logs/mylog.log 。
在web.xml 添加
- <context-param>
- <param-name>webAppRootKey</param-name>
- <param-value>webapp.root</param-value>
- </context-param>
- <context-param>
- <param-name>log4jConfigLocation</param-name>
- <param-value>/WEB-INF/log4j.properties</param-value>
- </context-param>
- <context-param>
- <param-name>log4jRefreshInterval</param-name>
- <param-value>60000</param-value>
- </context-param>
- <listener>
- <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
- </listener>
- webAppRootKey,即为放入当前JVM的环境变量名。
- log4jConfigLocation,log4j.properties的路径,可以放在/WEB-INF/下。
- log4jRefreshInterval, 开一条watchdog线程每60秒扫描一下配置文件的变化; 可以不配置这个参数。
- listener需要放在spring的Listener之前。
本文介绍了如何在Spring框架中使用Log4jConfigListener来指定log4j配置文件的位置及日志文件路径,并展示了如何在web.xml中进行相应配置。
3366

被折叠的 条评论
为什么被折叠?



