最近对log4j的日志配置小有兴趣,仔细研究了下,终于有了清晰的认识,顺便做了个日志文件的模板,方便以后查看和使用,顺便也为那些跟我当初一样,看日志文件看得云里雾里的朋友提供点详细的简单的资料。
#配置总的日志级别和输出目的:注意总的日志级别会覆盖掉下面输出目的地各自的日志级别,本人设置为空及日志级别由各子项自己控制 #A1 A2分别是输出目的地的名字:本人A1设置为控制台打印 A2设置为记录日志到文件 log4j.rootLogger= ,A1, A2 #A1输出的详细配置ConsoleAppender为控制台输出 log4j.appender.A1=org.apache.log4j.ConsoleAppender #Threshold 属性:翻译为 门限的意思,可想而知是配置限制输出的日志的级别的意思, #注意这个日志级别会被rootLogger(根日志)限制及比rootLogger日志级别低的日志是不能输出的 log4j.appender.A1.Threshold=info #layout显而易见是布局的意思,PatternLayout布局模式是可以灵活指定输出格式的布局模式 log4j.appender.A1.layout=org.apache.log4j.PatternLayout #ConversionPattern属性为怎样格式化的指定:%d为时间的输出,可以自己指定 #%p输出打印的日志的级别,即 DEBUG,INFO,WARN,ERROR..其中的一个 #%c输出日志信息所属的类目,通常就是所在类的全名,如org.apache.log4j.Logger;{2}限制输出的目录%c{2}输出为log4j.Logger #%F: 输出日志消息产生时所在的文件名称%L: 输出代码中的行号,如:Test0815.java:16(16为行号) #%m为输出的日志内容%n为输出换行回车;总的输出例子:****-**-** **:**:** WARN MOD1408.Test0815(Test0815.java:16) - this is warn log4j.appender.A1.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %p %c{2}(%F:%L) - %m%n #A2输出设置DailyRollingFileAppender(及每天产生一个日志文件) log4j.appender.A2=org.apache.log4j.DailyRollingFileAppender #日志文件的位置及文件名 log4j.appender.A2.File=D:\forWork\Logs\log4j.log log4j.appender.A2.Threshold=warn #Append属性:默认值是 true,即将消息增加到指定文件中,false 指将消息覆盖指定的文件内容 log4j.appender.A2.Append=true #ImmediateFlush=true:默认值是 true,意谓着所有的消息都会被立即输出 log4j.appender.A2.ImmediateFlush=true log4j.appender.A2.layout=org.apache.log4j.PatternLayout log4j.appender.A2.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %p %c{2}(%F:%L)%1x- %m%n #DatePattern更新日志的频率设置,下面是每天更新一个日志文件,名字为log4j.log.****-**-**.log,做为存储历史日志的文件 #设置的log4j.log文件始终是存储的当天的新的日志 log4j.appender.A2.DatePattern='.'yyyy-MM-dd'.log' #打出org.apache.ibatis类产生的debug级别日志 log4j.logger.org.apache.ibatis=debug #打出java.sql类及子类产生的debug级别的信息 log4j.logger.java.sql=debug #打出org.springframework类及子类产生的warn级别信息 log4j.logger.org.springframework=warn #要打印其它框架的日志去找相关的文档