一、示例
log4j.rootLogger=INFO, CONSOLE, FILE
## console 配置文件输出的目的地 (控制台)
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=%d{yyyy/MM/dd/HH:mm:ss} %-5p [%t] %10l - %m%n
## file 配置文件输出的目的地 (写入日志文件)
log4j.appender.FILE=org.apache.log4j.RollingFileAppender
log4j.appender.FILE.File=D:/logs/log4j.log
log4j.appender.FILE.MaxFileSize=1MB
log4j.appender.FILE.Append = true
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.ConversionPattern=%d{yyyy/MM/dd/HH:mm:ss} %-5p [%t] %10l - %m%n
二、详解
log4j.rootLogger=INFO, CONSOLE, FILE
1. 第一参数(INFO)代表日志级别
日志级别有五个: *** DEBUG INFO WARN ERROR FATAL ***
- DEBUG 我们为程序设定的一些调试信息
- INFO 为一般 要显示的信息 ,比如登陆,参数的值
- WARN 一般为警告信息 ,比如说session丢失,文件路径不存在
- ERROR 一般为异常信息 用于异常打印
2.第二个和第三个参数代表日志信息的输出地点
输出地点分五个类型
- org.apache.log4j.ConsoleAppender(控制台)
- org.apache.log4j.FileAppender(文件)
- org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
- org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
- org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方–邮箱)
3.日志信息的输出格式风格(layout)
- org.apache.log4j.HTMLLayout(以HTML表格形式布局),
- org.apache.log4j.PatternLayout(可以灵活地指定布局模式),
- org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
- org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
4.日志时间点输出格式(%d{})
比如:%d{yyy MMM dd HH:mm:ss},输出类似:2011年10月18日 22:10:28
- %p: 输出日志信息优先级,即DEBUG,INFO,WARN,ERROR,FATAL,
- %t: 输出产生该日志事件的线程名
- %c: 输出日志信息所属的类目,通常就是所在类的全名
- %l: 输出代码中的行号
- %m: 输出代码中指定的消息,产生的日志具体信息
- %n: 输出一个回车换行符