文章目录
前言
项目中采用了log4j+slf4j的日志框架采集日志,在项目调优过程中对日志输出内容进行了调整,借此机会对整个配置有更全面的了解。
示例:
参数详情
①配置根Logger,其语法为:
log4j.rootLogger =[level],appenderName,appenderName2,…
level是日志记录的优先级,分为OFF,TRACE,DEBUG,INFO,WARN,ERROR,FATAL,ALL
Log4j建议只使用四个级别,优先级从低到高分别是DEBUG,INFO,WARN,ERROR
通过在这里定义的级别,您可以控制到应用程序中相应级别的日志信息的开关
比如在这里定义了INFO级别,则应用程序中所有DEBUG级别的日志信息将不被打印出来
appenderName就是指定日志信息输出到哪个地方。可同时指定多个输出目的
②配置日志信息输出目的地Appender,其语法为:
log4j.appender.appenderName =fully.qualified.name.of.appender.class
log4j.appender.appenderName.optionN =valueN
Log4j提供的appender有以下几种:
-
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(将日志信息以流格式发送到任意指定的地方)
ConsoleAppender选项属性
-Threshold = DEBUG:指定日志消息的输出最低层次
-ImmediateFlush = TRUE:默认值是true,所有的消息都会被立即输出
-Target = System.err:默认值System.out,输出到控制台(err为红色,out为黑色)
FileAppender选项属性
-Threshold = INFO:指定日志消息的输出最低层次
-ImmediateFlush = TRUE:默认值是true,所有的消息都会被立即输出
-File = C:\log4j.log:指定消息输出到C:\log4j.log文件
-Append = FALSE:默认值true,将消息追加到指定文件中,false指将消息覆盖指定的文件内容
-Encoding = UTF-8:可以指定文件编码格式
DailyRollingFileAppender选项属性
-Threshold = WARN:指定日志消息的输出最低层次
-ImmediateFlush = TRUE:默认值是true,所有的消息都会被立即输出
-File =C:\log4j.log:指定消息输出到C:\log4j.log文件
-Append= FALSE:默认值true,将消息追加到指定文件中,false指将消息覆盖指定的文件内容
-DatePattern=’.'yyyy-ww:每周滚动一次文件,即每周产生一个新的文件。还可以按用以下参数:
'.'yyyy-MM:每月
'.'yyyy-ww:每周
'.'yyyy-MM-dd:每天