浏览 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等等;最终希望能有高人给出更好的解决方案。
声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2009-08-13
很简单呀 日志不要放在webapp下面呀 放外部路径不就行了嘛?
|
|
返回顶楼 | |
发表时间:2009-08-14
joyfun 写道 很简单呀 日志不要放在webapp下面呀 放外部路径不就行了嘛? 噫,是哦,是种办法,回头赶紧试试。 |
|
返回顶楼 | |
发表时间:2009-08-14
是啊,别放在webapp目录下,我前几天也在弄日志的东西,放在webapp目录几天又改到其他地方去了
|
|
返回顶楼 | |
发表时间:2009-08-14
最后修改:2009-08-14
|
|
返回顶楼 | |
发表时间:2009-08-15
遇到问题应该反过头来想想,为什么日志文件一定要放至webapp目录下呢。呵呵。
|
|
返回顶楼 | |