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

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

 

      经过一翻查找,最终知道导致这一错误的罪魁祸首是在Tomcat server.xml中所设置的所导致的,由于加了这一设置,日志文件始终被其占有,所以当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等等;最终希望能有高人给出更好的解决方案。

 

你可能感兴趣的:(服务器)