Log4j应用

rel="File-List" href="file:///C:%5CDOCUME%7E1%5CADMINI%7E1%5CLOCALS%7E1%5CTemp%5Cmsohtml1%5C01%5Cclip_filelist.xml">

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. log4j.rootLogger = debug,appender1,appender2
  2. log4j.appender.appender1 = org.apache.log4j.FileAppender
  3. log4j.appender.appender1.File =f:/unicorn.htm
  4. log4j.appender.appender1.layout=org.apache.log4j.HTMLLayout
  5. log4j.appender.appender2 = org.apache.log4j.ConsoleAppender
  6. log4j.appender.appender2.layout = org.apache.log4j.TTCCLayout

rel="File-List" href="file:///C:%5CDOCUME%7E1%5CADMINI%7E1%5CLOCALS%7E1%5CTemp%5Cmsohtml1%5C01%5Cclip_filelist.xml">

常用的有以下几个:

       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 输出一个换行符号

  1. log4j.rootLogger = debug,appender1,appender2
  2. log4j.appender.appender1 = org.apache.log4j.FileAppender
  3. log4j.appender.appender1.File =f:/unicorn.htm
  4. log4j.appender.appender1.layout=org.apache.log4j.HTMLLayout
  5. log4j.appender.appender2 = org.apache.log4j.ConsoleAppender
  6. log4j.appender.appender2.layout = org.apache.log4j.PatternLayout
  7. log4j.appender.appender2.layout.ConversionPattern = %r [%t]  %p - %c -%l -%m%n

rel="File-List" href="file:///C:%5CDOCUME%7E1%5CADMINI%7E1%5CLOCALS%7E1%5CTemp%5Cmsohtml1%5C01%5Cclip_filelist.xml">

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());

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值