论坛首页 入门技术论坛

可恶的log4j:ERROR Failed to rename终于搞定了

浏览 5726 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2009-08-13   最后修改:2009-08-13

      在Tomcat6下使用Log4j记录日志,遇到一个烦心的问题,就是每天创建新日志文件时(日志文件设置为:org.apache.log4j.DailyRollingFileAppender)报:log4j:ERROR Failed to rename错误; 错误 出现 之后,最可恶的事情也随之而来,不但没有把前一天的日志 保存好 ,而是把前面所有日志统统给覆盖掉,气的你会吐血

 

      经过一翻查找,最终知道导致这一错误的罪魁祸首是在Tomcat server.xml中所设置的<Context docBase="xxxx" path="/" reloadable="true"/>所导致的,由于加了这一设置,日志文件始终被其占有,所以当log4j对日志文件进行rename时,就发生了Failed to rename错误

 

     由于log4j在实现日志文件备份时使用的是file.renameTo(File)方法:

File file = new File(fileName);   
    boolean result = file.renameTo(target);

    if(result) {   
      LogLog.debug(fileName +" -> "+ scheduledFilename);   
    } else {   
      LogLog.error("Failed to rename ["+fileName+"] to ["+scheduledFilename+"].");   
    }  
 

 

     而File类的renameTo方法的作用是:”改名或者移动文件作用;在同一个目录下renameTo是改名,在不同目录下是移动",所以在对一个被其他线程所锁定的文件进行改名时,肯定是会报错的。

 

    为解决这一错误, 想来想去最终还是采用了http://duanni.iteye.com/blog/177271 的解决方案,修改了log4j源码,把file.renameTo(File)方法更改成copy文件了,算是解决了问题。不过还是有点担心,就像icefox_wjx 所说的一样,仍然无法预料操作系统会不会出现什么样的情况,如不允许文件copy等等;最终希望能有高人给出更好的解决方案。

 

   发表时间:2009-08-13  
很简单呀 日志不要放在webapp下面呀 放外部路径不就行了嘛?
0 请登录后投票
   发表时间:2009-08-14  
joyfun 写道
很简单呀 日志不要放在webapp下面呀 放外部路径不就行了嘛?

噫,是哦,是种办法,回头赶紧试试。
0 请登录后投票
   发表时间:2009-08-14  
是啊,别放在webapp目录下,我前几天也在弄日志的东西,放在webapp目录几天又改到其他地方去了
0 请登录后投票
   发表时间:2009-08-14   最后修改:2009-08-14
不要觉得可恶

http://www.iteye.com/topic/286569?page=2#776491
0 请登录后投票
   发表时间:2009-08-15  
遇到问题应该反过头来想想,为什么日志文件一定要放至webapp目录下呢。呵呵。
0 请登录后投票
论坛首页 入门技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics