Log4j记日志功能
1、Log4j有三个主要的组件:Loggers(记录器),Appenders (输出源)和Layouts(布局)。这里可简单理解为日志类别,日志要输出的地方和日志以何种形式输出。
2、Log4j格式详解
log4j.rootLogger = 日志级别,appender1, appender2, ….
- 日志级别:ALL<DEBUG<INFO<WARN<ERROR<FATAL<OFF,不区分大小写
- 注意,需在控制台输入,只需将其中一个appender定义为stdout即可。(只是定义输出源的名称)
- 注意,rootLogger默认是对整个工程生效,如果只想对某些包操作,那么:log4j.logger.com.hutu=info, stdout,表示该日志对package com.hutu生效
log4j.appender.appender1 = org.apache.log4j.日志输出到哪儿
- ConsoleAppender(控制台),可选属性 Threshold (默认DEBUG)、ImmediateFlush(默认=true)、Target(默认=System.out)
- FileAppender(文件) ,可选属性 Threshold 、ImmediateFlush、Append(默认=true)、File
- DailyRollingFileAppender(每天产生一个日志文件),可选属性 Threshold 、ImmediateFlush、Append、DatePattern
- RollingFileAppender(文件大小到达指定尺寸时产生一个新的文件) ,可选属性 Threshold 、ImmediateFlush、Append、File、MaxFileSize、MaxBackupIndex
- WriteAppender(将日志信息以流格式发送到任意指定的地方)
- JDBCAppender(将日志信息保存到数据库中)
log4j.appender.appender1.File=文件目录及文件${user.home}/logs/...
log4j.appender.appender1.MaxFileSize=最大文件大小
log4j.appender.appender1.MaxBackupIndex=备份文件个数
log4j.appender.appender1.DatePattern=对应格式文件(滚动日志)
log4j.appender.appender1.Threshold = 日志级别
log4j.appender.ServerDailyRollingFile.Append=true
- 文件目录及文件,例如,/home/admin/logs/hutudan.log
- 最大文件大小,例如,100KB
- 备份文件个数,例如,1
- '.'yyyy-MM : 每月 ; '.'yyyy-ww:每周 ; '.'yyyy-MM-dd:每天 ; ':每天两次
'.'yyyy-MM-dd-HH:每小时 ; '.'yyyy-MM-dd-HH-mm:每分钟
- 输出日记级别以上的 日志,例如:debug,info
- 追加上一次的文件后面,继续写
log4j.appender.ServerDailyRollingFile.DatePattern=日志后缀格式
- 例如,'.'yyyy-MM-dd
log4j.appender.appender1.layout=org.apache.log4j.日志布局格式
- HTMLLayout(以HTML表格形式布局)
- SimpleLayout(包含日志信息的级别和信息字符串)
- TTCCLayout(包含日志产生的时间,执行绪,类别等信息)
- PatternLayout(可以灵活的指定布局格式,常用)
log4j.appender.appender1.layout.ConversionPattern=日志输出格式
- 例如,%d - %m%n或%d{yyyy-MM-dd HH:mm:ss} %p [%c] %m%n
- %c 输出日志信息所属的类的全名
- %d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy-MM-dd HH:mm:ss },输出类似:2002-10-18 22:10:28
- %f 输出日志信息所属的类的类名
- %l 输出日志事件的发生位置,即输出日志信息的语句处于它所在的类的第几行
- %m 输出代码中指定的信息,如log(message)中的message
- %n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”
- %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL。如果是调用debug()输出的,则为DEBUG,依此类推
- %r 输出自应用启动到输出该日志信息所耗费的毫秒数
- %t 输出产生该日志事件的线程名
总结:
- Logger类:完成日志记录,设置日志信息级别
- Appender类:决定日志去向,终端、DB、硬盘
- Layout类:决定日志输出的样式,例如包含当前线程、行号、时间
附录:一张可供参考的配置
#定义LOG输出级别 log4j.rootLogger=INFO,Console,F,E #定义mybatis日志输出 log4j.logger.org.mybatis=INFO,ibatis log4j.logger.com.software.dao=INFO,ibatis log4j.additivity.org.mybatis=false log4j.appender.ibatis=org.apache.log4j.DailyRollingFileAppender log4j.appender.ibatis.File=../logs/shuichan/ibatis/ibatis.log log4j.appender.ibatis.layout=org.apache.log4j.PatternLayout log4j.appender.ibatis.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss} method:%c%n%m%n #定义日志输出目的地为控制台 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:%c%n%m%n #可以灵活地指定日志输出格式,下面一行是指定具体的格式 #log4j.appender.Console.layout = org.apache.log4j.PatternLayout #log4j.appender.Console.layout.ConversionPattern=[%c] - %m%n #文件大小到达指定尺寸的时候产生一个新的文件 log4j.appender.F = org.apache.log4j.RollingFileAppender #指定输出目录 log4j.appender.F.File = ../logs/shuichan/logfile.log log4j.appender.F.Append = true #定义文件最大大小 log4j.appender.F.MaxFileSize = 10MB # 输出所以日志,如果换成DEBUG表示输出DEBUG以上级别日志 log4j.appender.F.Threshold = INFO log4j.appender.F.layout = org.apache.log4j.PatternLayout log4j.appender.F.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH\:mm\:ss,SSS}][%c]%m%n ### 输出ERROR 级别以上的日志到=E://logs/error.log ### log4j.appender.E = org.apache.log4j.DailyRollingFileAppender log4j.appender.E.File = ../logs/shuichan/error.log 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,SSS} [ %t:%r ] - [ %p ] %c%m%n
George93