1.Log4j核心
a) Logger à Logger完成日志信息的处理
Logger可以定义输出的层次和决定信息是否输出
Logger 输出的信息是有优先级别的:
ALL,TRACE,DEBUG,INFO,WARN,ERROR,FATAL,OFF
ALL < TRACE < DUBUG < INFO < WARN < ERROR < FATAL < OFF
Logger:
log.debug(“x=”+x);
log.info(“System started at “ + new Date());
log.warn(“Server down –returning”);
log.error(“Could not access server”,e);
b) AppenderàAppender设置日志信息的去向
Appender就是设置日志讯息输出到哪个地方.可以同时指定多个输出目的地.
log4j.appender.apperderName = Appender.class
log4j.appender.appenderName.option1 = value1
log4j.appender.appenderName.optionN = valueN
例如:
常用的有以下几个:
1. org.apache.log4j.ConsoleAppender(控制台)
2. org.apache.log4j.FileAppender(文件)
3. org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
4.org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件
5.org.apache.log4j.WriterAppender(将日志信息以串流格式发送到任意指定的地方)
6. org.apache.log4j.JdbcAppender(将日志信息保存到数据库中);
c) Layout à Layout设置日志信息的输出样式
配置格式如下:
log4j.appender.appenderName.layout = Layout.class
log4j.appender.appenderName.layout.option1 = value1
Log4j提供的layout有以下几种:
org.apache.log4j.HTMLLayout(以HTML表格形式布局)
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符长)
org.apache.log4j.TTCCLayout(包含日志产生的时间,类别等等信息)
org.apache.log4j.PatternLayout(可以灵活地指定布局模式);
PatternLayout
用来定制所输出的日志信息的样式
1. %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL等
2. %r 输出自应用启动到输出该日志信息所耗费的毫秒数
3. %t 输出产生该日志事件的线程名
4. %f 输出日志信息所属的类别的类别名
5. %c 输出日志信息所属的类的全名
6. %d 输出日志时间点的日期或时间,指定格式的方式:%d{yyyy-MM-dd HH:mm:ss}
7. %l 输出日志事件的发生位置,即输出日志信息的语句处于它所在的类别的第几行.
8. %m 输出代码中指定的信息,如log(message)中的message
9. %n 输出一个换行符号
RootLogger
1. log4j.rootLogger = [level],appenderName,appenderName….
2. 上面的设定将输出等级设置为INFO,就表示INFO~FATAL等级的信息将会输出,DEBUG等级的信息就会被忽略
关于性能影响:
1. Log4j对程序的运行的性能影响非常小.
2. 还可以通过下面的方式,降低性能影响
rel="File-List" href="file:///C:%5CDOCUME%7E1%5CADMINI%7E1%5CLOCALS%7E1%5CTemp%5Cmsohtml1%5C01%5Cclip_filelist.xml">
If(log.isDebugEnabled()){
log.debug(“x=”+longRunning());
}