您的位置:首页 > 编程语言 > Java开发

log4j日志文件的相对位置设置的完美解决方案

2008-10-21 16:44 453 查看
     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之前。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  log4j spring jvm web