Log4j每天、每小时、每分钟定时生成日志文件
2012-12-25 13:16
357 查看
在做项目中基本上都用到了日志log,那么自然就会遇到问题,比方说,日志太大了怎么办?日志很乱怎么办?
这时我们就会想到如果能够把日志分为定时的生成即:Log4j每天、每小时、每分钟定时生成日志文件这样多好,既可以方便存储亦利于查看。针对这个一想法,本人做了下测试,发现效果还是可以的,特把代码以及配置贴出以便初学者参考:
一、首先添加必须的jar文件,如:commons-logging.jar、log4j.jar等这些,这个就不说了;
二、Web.xml配置:
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
一定要加上这个监听,测试过好几遍,如果不加上此监听,那么无法定时把Log中的数据存储到文件中,即:定时生成日志文件;
三、log4j.properties文件编写:
下面为此次关键的部分
#LogFile Write
log4j.logger.logcase= INFO, dufLog
log4j.appender.dufLog=org.apache.log4j.DailyRollingFileAppender
log4j.appender.dufLog.File=${webapp.root}WEB-INF/logfiles/logcase/logcase
log4j.appender.dufLog.DatePattern = '_'yyyy-MM-dd-HH-mm'.log'
log4j.appender.dufLog.MaxFileSize=10MB
log4j.appender.dufLog.layout=org.apache.log4j.PatternLayout
log4j.appender.dufLog.layout.ConversionPattern=%d%n%m%n
其中logcase为所需要产生日志的bean中所定义的;一般来说,一个项目中有很多种日志,即:每种日志生成不同的文件,如:有服务启动日志,有bug处理日志.....为了不让所有的日志在一起混合,所以就需要自定义日志来针对不同的功能模块;
上面${webapp.root}默认表示项目的根目录,整句表示日志文件将处于目录:WEB-INF/logfiles/logcase/logcase;
DatePattern中配置的'_'yyyy-MM-dd-HH-mm'.log' 意思是根据这个时间来定时生成文件,并且把'_'yyyy-MM-dd-HH-mm'.log'附加在原文件的后面,即:logcase_'yyyy-MM-dd-HH-mm'.log', 由于定义到mm所以就每分钟生成一次。
四、Log产生Bean<这里使用Struts2来测试>;
这里的自定义Log标识:logcase就必须要与log4j.properties中的相对应,
好,上面的配置已经完成,启动服务、运行次Action中的方法,即可记录日志信息,如下图所示:
这时我们就会想到如果能够把日志分为定时的生成即:Log4j每天、每小时、每分钟定时生成日志文件这样多好,既可以方便存储亦利于查看。针对这个一想法,本人做了下测试,发现效果还是可以的,特把代码以及配置贴出以便初学者参考:
一、首先添加必须的jar文件,如:commons-logging.jar、log4j.jar等这些,这个就不说了;
二、Web.xml配置:
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
一定要加上这个监听,测试过好几遍,如果不加上此监听,那么无法定时把Log中的数据存储到文件中,即:定时生成日志文件;
三、log4j.properties文件编写:
下面为此次关键的部分
#LogFile Write
log4j.logger.logcase= INFO, dufLog
log4j.appender.dufLog=org.apache.log4j.DailyRollingFileAppender
log4j.appender.dufLog.File=${webapp.root}WEB-INF/logfiles/logcase/logcase
log4j.appender.dufLog.DatePattern = '_'yyyy-MM-dd-HH-mm'.log'
log4j.appender.dufLog.MaxFileSize=10MB
log4j.appender.dufLog.layout=org.apache.log4j.PatternLayout
log4j.appender.dufLog.layout.ConversionPattern=%d%n%m%n
其中logcase为所需要产生日志的bean中所定义的;一般来说,一个项目中有很多种日志,即:每种日志生成不同的文件,如:有服务启动日志,有bug处理日志.....为了不让所有的日志在一起混合,所以就需要自定义日志来针对不同的功能模块;
上面${webapp.root}默认表示项目的根目录,整句表示日志文件将处于目录:WEB-INF/logfiles/logcase/logcase;
DatePattern中配置的'_'yyyy-MM-dd-HH-mm'.log' 意思是根据这个时间来定时生成文件,并且把'_'yyyy-MM-dd-HH-mm'.log'附加在原文件的后面,即:logcase_'yyyy-MM-dd-HH-mm'.log', 由于定义到mm所以就每分钟生成一次。
四、Log产生Bean<这里使用Struts2来测试>;
这里的自定义Log标识:logcase就必须要与log4j.properties中的相对应,
好,上面的配置已经完成,启动服务、运行次Action中的方法,即可记录日志信息,如下图所示:
相关文章推荐
- Log4j每天、每小时、每分钟定时生成日志文件
- [java][log4j]Log4j每天、每小时、每分钟定时生成日志文件
- Log4j每天、每小时、每分钟定时生成日志文件
- [java][log4j]Log4j每天、每小时、每分钟定时生成日志文件
- log4j每天,每小时产生一日志文件
- log4j配置每天生成一个日志文件
- 如何配置log4j每天产生日志,并且当天日志大于10M时自动生成另一个文件
- log4j配置每天生成一个日志文件
- Log4j使用笔记:每天生成一个日志文件、按日志大小生成文件
- log4j 每天生成日志文件 错误文件
- log4j配置每天生成一个日志文件
- log4j 每天生成一个日志文件
- Tomcat下使用Log4j 接管 catalina.out 日志文件生成方式,按天存放,解决catalina.out日志文件过大问题
- log4j按时生成日志文件
- crontab每分钟、每小时、每天、每周、每月、每年定时执行
- log4j输出日志到指定文件并定时备份
- log4j输出日志到指定文件并定时备份
- tomcat 6.x + log4j日志配置并按天(或大小)生成文件
- 限制Apache日志文件大小和每天生成日志文件的方法
- Log4j 生成日志文件(路径)