(一)、log4j

说明:log4j 日志管理目前最新版为 log4j2, 版本更新依次为 log4j → logback → log4j2。
  • 第一代log4j的配置文件为.properties格式,logback和log4j2的配置文件开始采用.xml格式文件。
  • logback较第一代log4j增加了许多新功能,如异步输出等等,性能方面也有很高提升。
  • log4j2在logback基础上对日志输出功能方面有了进一步的改进,且性能又提高了一个档次。
如想直接学习log4j2可以直接跳转本人log4j2博客。

log4j.properties 配置:
#控制台一般输出
log4j.appender.leixin.Console=org.apache.log4j. ConsoleAppender
log4j.appender.leixin.Console.target= System.out
log4j.appender.leixin.Console.layout=org.apache.log4j.PatternLayout   
log4j.appender.leixin.Console.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} %5p (%c:%M) - %m%n

#控制台红色日志输出
log4j.appender.leixin.eConsole=org.apache.log4j.ConsoleAppender
log4j.appender.leixin.eConsole.target=System.err
log4j.appender.leixin.eConsole.layout=org.apache.log4j.PatternLayout
log4j.appender.leixin.eConsole.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} %5p (%c) - %m%n

#按每天一个日志文件输出
log4j.appender.leixin.File=org.apache.log4j. DailyRollingFileAppender
log4j.appender.leixin.File.file=d:\\log\\leixin.log
log4j.appender.leixin.File.DatePattern='.'yyyy-MM-dd
log4j.appender.leixin.File.layout=org.apache.log4j.PatternLayout
log4j.appender.leixin.File.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} %5p (%C:%M) - %m%n

#按固定大小日志文件输出
log4j.appender.leixin.RFile=org.apache.log4j. RollingFileAppender
log4j.appender.leixin.RFile.file=d:\\log\\leixinRF.log
log4j.appender.leixin.RFile.MaxFileSize=2000KB
log4j.appender.leixin.RFile.MaxBackupIndex=10
log4j.appender.leixin.RFile.layout=org.apache.log4j.PatternLayout
log4j.appender.leixin.RFile.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} %5p (%r:%C:%M) - %m%n

#Logger配置(日志级别/输出方式)
log4j.rootLogger=info, leixin.File, leixin.Console
#log4j.logger.com.leixin.dao=warn, leixin.Console, leixin.File
#log4j.logger.com.leixin=debug, leixin.Console, leixin.File
#log4j.logger.com.leixin.dao=info, leixin.Console, leixin.File

解析:
1、Appender
  • org.apache.log4j.ConsoleAppender(输出到控制台)
    • .target=System.err:默认值System.out,输出到控制台(err为红色,out为黑色)
  • org.apache.log4j.FileAppender(输出到文件)
    • .file =C:\log4j.log:指定消息输出到C:\log4j.log文件
    • .append = FALSE:默认值true(默认不覆盖)。
      • true将消息追加到指定文件中;false将消息覆盖指定的文件内容
    • .Encoding = UTF-8:可以指定文件编码格式
  • org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件) 
    • .file=C:\log4j.log:指定消息输出到C:\log4j.log文件
    • .append= TRUE:默认值true,将消息追加到指定文件中,false指将消息覆盖指定的文件内容
    • .Encoding= UTF-8:可以指定文件编码格式
    • .DatePattern='.'yyyy-ww:每周滚动一次文件,即每周产生一个新的文件。
      • 还可以按用以下参数设置:
        • '.'yyyy-MM:每月
        • '.'yyyy-ww:每周
        • '.'yyyy-MM-dd:每天
        • '.'yyyy-MM-dd-a:每天两次
        • '.'yyyy-MM-dd-HH:每小时
        • '.'yyyy-MM-dd-HH-mm:每分钟
  • org.apache.log4j.RollingFileAppender (文件大小到达指定尺寸的时候产生一个新的文件)
    • .file =C:\log4j.log:指定消息输出到C:\log4j.log文件
    • .append = FALSE:默认值true,将消息追加到指定文件中,false指将消息覆盖指定的文件内容
    • .Encoding = UTF-8:可以指定文件编码格式
    • .MaxFileSize= 100KB:后缀可以是KB,MB,GB.在日志文件到达该大小时,将会自动滚动.如:log4j.log.1
      • 每一个文件最大值
    • .MaxBackupIndex= 10: 指定可以产生的滚动文件的最大数,默认是2
      • 生成log文件数量,多余的旧日志文件将会被清除。


2、Layout
     Log4j提供的layout有以下几种
  • org.apache.log4j.HTMLLayout(以HTML表格形式布局)
  • org.apache.log4j.PatternLayout(可以灵活地指定布局模式)
ConversionPattern=[%5p]-%d{yyyy-MM-ddHH:mm:ss,SSS} (%C:%M: %L) - %m%n
  • %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
    • p前面的数字表示占字位,如 %5p:INFO 输出为 " INFO"
  • %d 输出日志时间点的日期或时间,默认格式为 ISO8601 ,也可以在其后指定格式
    • 如:%d{yyyy年MM月dd日 HH:mm:ss,SSS},输出类似:2012年01月05日 22:10:28,921
  • %C 输出所属的类目,通常就是所在类的全名
  • %M 输出所属类的方法
  • %L 输出代码中的行号
  • %m 输出代码中指定的消息
  • %n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”

  • %c 输出Logger.getLogger(Clazzclass)中参数的class名
  • %t 输出产生该日志事件的线程名
  • %l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数
    • 如:Testlog.main(TestLog.java:10)
  • %F 输出日志消息产生时所在的文件名称
  • %% 输出一个"%"字符

  • org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)
  • org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
  • org.apache.log4j.xml.XMLLayout(以XML形式布局)

3、Logger
  • 日志级别:(tracedebuginfowarnerrorfatal)
  • 当多个logger都可以与传入参数的类匹配时,logger如何选择? 级别看精确,输出为各自
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值