#建议只适应四个级别,从低到高 DEBUG INFO WARN ERROR
log4j.rootLogger = INFO,console,infofile,errorfile #warnfile
log4j.addivity.org.apache = true
### 输出信息到控制台 ###
log4j.appender.console = org.apache.log4j.ConsoleAppender
log4j.appender.console.target = System.out
log4j.appender.console.encoding = UTF-8
log4j.appender.console.layout = org.apache.log4j.PatternLayout
#日志输出格式
log4j.appender.console.layout.ConversionPattern = %-d{HH\:mm\:ss}[%p]-[%c] %m%n
#打印mybatis debug日志(一般没必要)
#log4j.logger.org.apache.ibatis=DEBUG
#对应程序的dao层 打印sql语句
log4j.logger.com.jxqf.dao=DEBUG
### 输出到文件file info ###
log4j.logger.infofile = info
log4j.appender.infofile = org.apache.log4j.DailyRollingFileAppender
log4j.appender.infofile.append = true
log4j.appender.infofile.Threshold = INFO
log4j.appender.infofile.datePattern = '.'yyyy-MM-dd'.log'
log4j.appender.infofile.MaxFileSize=100000KB
log4j.appender.infofile.layout = org.apache.log4j.PatternLayout
log4j.appender.infofile.File = ${catalina.home}/logs_project/info.log
log4j.appender.infofile.layout.ConversionPattern = [%-5p]_%d{yyyy-MM-dd HH:mm:ss} %c - %m%n
#使用日志输出过滤
log4j.appender.infofile.filter.F1=org.apache.log4j.varia.LevelRangeFilter
log4j.appender.infofile.filter.F1.LevelMin=INFO
log4j.appender.infofile.filter.F1.LevelMax=INFO
### 输出到文件file error ###(每天产生一个日志文件:DailyRollingFileAppender)
log4j.appender.errorfile = error
log4j.appender.errorfile = org.apache.log4j.DailyRollingFileAppender
log4j.appender.errorfile.append = true
log4j.appender.errorfile.Threshold = ERROR
log4j.appender.errorfile.datePattern = '.'yyyy-MM-dd'.log'
log4j.appender.errorfile.layout = org.apache.log4j.PatternLayout
log4j.appender.errorfile.File = ${catalina.home}/logs_project/error.log
log4j.appender.errorfile.layout.ConversionPattern = [%-5p] [%d{HH:mm:ss}] %c - %m%n
og4j.appender.myfile.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} [%t] [%c] [%p] [%L]- %m%n ,日志的布局方式,%开头的字符意义如下:
%p:输出日志信息的优先级,即DEBUG,INFO,WARN,ERROR,FATAL。
%d:输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,如:%d{yyyy/MM/dd HH:mm:ss,SSS}。
%r:输出自应用程序启动到输出该log信息耗费的毫秒数。
%t:输出产生该日志事件的线程名。
%l:输出日志事件的发生位置,相当于%c.%M(%F:%L)的组合,包括类全名、方法、文件名以及在代码中的行数。例如:test.TestLog4j.main(TestLog4j.java:10)。
%c:输出日志信息所属的类目,通常就是所在类的全名。
%M:输出产生日志信息的方法名。
%F:输出日志消息产生时所在的文件名称。
%L::输出代码中的行号。
%m::输出代码中指定的具体日志信息。
%n:输出一个回车换行符,Windows平台为”\r\n”,Unix平台为”\n”。
%x:输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中。
参考博客:https://blog.csdn.net/cavvv/article/details/46345035
https://blog.csdn.net/qq315737546/article/details/54589404
Log4j每天、每小时、每分钟定时生成日志文件
在做项目中基本上都用到了日志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中的方法,即可记录日志信息,如下图所示:
————————————————
版权声明:本文为CSDN博主「漫天雪_昆仑巅」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/vtopqx/article/details/8432862