1. 概述
1.1. 背景
在应用程序中添加日志记录总的来说基于三个目的 :监视代码中变量的变化情况,周期性的记录到文件中供其他应用进行统计分析工作;跟踪代码运行时轨迹,作为日后审计的依据;担当集成开发环境中的调试器的作用,向文件或控制台打印代码的调试信息。
最普通的做法就是在代码中嵌入许多的打印语句,这些打印语句可以输出到控制台或文件中,比较好的做法就是构造一个日志操作类 来封装此类操作,而不是让一系列的打印语句充斥了代码的主体。
#log4j.rootLogger = [ level ] , appenderName, appenderName, … level 优先级,ALL < DEBUG < INFO < WARN < ERROR < FATAL < OFF
log4j.rootLogger = debug,console,D,E
### 输出信息到控制台 ###
log4j.appender.console = org.apache.log4j.ConsoleAppender
log4j.appender.console.Target = System.out
log4j.appender.console.layout = org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n
### 输出DEBUG 级别以上的日志到=E://logs/error.log ### (每天产生一个日志文件)
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = E://logs/debug.log
log4j.appender.D.DatePattern='.'yyyy-MM-dd
log4j.appender.D.Append = true
#指定日志信息的最低输出级别,默认为DEBUG。 即dubug以上的都会打印 ,可不设置,即以log4j.rootLogger设置的等级为准
log4j.appender.D.Threshold = DEBUG
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
### 输出ERROR 级别以上的日志到=E://logs/error.log ###
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
log4j.appender.E.File =E://logs/error.log
log4j.appender.E.DatePattern='.'yyyy-MM-dd
log4j.appender.E.Append = true
log4j.appender.E.Threshold = ERROR
log4j.appender.E.layout = org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
#Log4j提供的appender有以下几种:
#1.org.apache.log4j.ConsoleAppender(控制台),
#2.org.apache.log4j.FileAppender(文件),
#3.org.apache.log4j.DailyRollingFileAppender
#DailyRollingFileAppender DatePattern选项解析:
#DatePattern='.'yyyy-MM:每月滚动一次日志文件,即每月产生一个新的日志文件。当前月的日志文件名为logging.log4j,前一个月的日志文件名为logging.log4j.yyyy-MM。
#另外,也可以指定按周、天、时、分等来滚动日志文件,对应的格式如下:
#1)'.'yyyy-MM:每月
#2)'.'yyyy-ww:每周
#3)'.'yyyy-MM-dd:每天
#4)'.'yyyy-MM-dd-a:每天两次
#5)'.'yyyy-MM-dd-HH:每小时
#6)'.'yyyy-MM-dd-HH-mm:每分钟
#4.org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),
#5.org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
# RollingFileAppender选项:
#Threshold=WARN:指定日志信息的最低输出级别,默认为DEBUG。
#ImmediateFlush=true:表示所有消息都会被立即输出,设为false则不输出,默认值是true。
#Append=false:true表示消息增加到指定文件中,false则将消息覆盖指定的文件内容,默认值是true。
#File=D:/logs/logging.log4j:指定消息输出到logging.log4j文件中。
#MaxFileSize=100KB:后缀可以是KB, MB 或者GB。在日志文件到达该大小时,将会自动滚动,即将原来的内容移到logging.log4j.1文件中。
#MaxBackupIndex=2:指定可以产生的滚动文件的最大数,例如,设为2则可以产生logging.log4j.1,logging.log4j.2两个滚动文件和一个logging.log4j文件。
#Log4j提供的layout有以e几种:
#org.apache.log4j.HTMLLayout(以HTML表格形式布局),
#org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
#org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
#org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
#Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下: %m 输出代码中指定的消息
#%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
#%r 输出自应用启动到输出该log信息耗费的毫秒数
#%c 输出所属的类目,通常就是所在类的全名
#%t 输出产生该日志事件的线程名
#%n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”
#%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
#%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java:10)