log4j.properties配置说明

1. log4j配置

# ALL,DEBUG,INFO,WARN,ERROR,FATAL,OFF
LOG_LEVEL=INFO
log4j.rootLogger=${LOG_LEVEL},CONSOLE,FILE,ERR # 打印日志到控制台
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.Encoding=utf-8
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
#log4j.appender.CONSOLE.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss} %C{8}@(%F:%L):%m%n
log4j.appender.CONSOLE.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss} %C{1}@(%F:%L):%m%n # 打印日志到文件
log4j.logger.FILE=INFO,FILE
log4j.appender.FILE=org.apache.log4j.RollingFileAppender
log4j.appender.FILE.File=${catalina.base}/logs/admin.log
log4j.appender.FILE.Encoding=utf-8
log4j.appender.R.MaxFileSize=100MB
log4j.appender.R.MaxBackupIndex=100
log4j.appender.FILE.DatePattern='.'yyyy-MM-dd
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
#log4j.appender.FILE.layout=org.apache.log4j.HTMLLayout
log4j.appender.FILE.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH\:mm\:ss} %C{8}@(%F\:%L)\:%m%n

2. LOG_LEVEL的级别说明

  LOG_LEVEL为日志的输出级别,共有7级:OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL

  • off 最高等级,用于关闭所有日志记录。
  • fatal 指出每个严重的错误事件将会导致应用程序的退出。
  • error 指出虽然发生错误事件,但仍然不影响系统的继续运行。
  • warm 表明会出现潜在的错误情形。
  • info 一般和在粗粒度级别上,强调应用程序的运行全程。
  • debug 一般用于细粒度级别上,对调试应用程序非常有帮助。
  • all 最低等级,用于打开所有日志记录。

  Log4j只建议使用4个级别,优先级从高到低分别是error,warn,info和debug。如果在使用了info级别的日志,只会输出info级别下info、debug等的日志,warn、error等日志不会被打印。

3. appender的日志输出方式

  • org.apache.log4j.ConsoleAppender :以控制台方式输出日志
  • org.apache.log4j.FileAppender :以文件形式输出日志
  • org.apache.log4j.DailyRollingFileAppender :以每天产生一个日志文件
  • org.apache.log4j.RollingFileAppende :转动输出,当文件达到指定大小产生一个新文件
  • org.apache.log4j.WriterAppender :以流的形式输出到其它地方

如:输出到控制台

log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender

4. layout日志输出格式说明

  • org.apache.log4j.HTMLLayout :以HTML表格形式布局
  • org.apache.log4j.PatternLayout :可以灵活地指定布局模式
  • org.apache.log4j.SimpleLayout :包含日志信息的级别和信息字符串
  • org.apache.log4j.TTCCLayout :包含日志产生的时间、线程、类别等等信息

一般使用PatternLayout,自己配置输出格式。

5. 输出格式参数说明

Log4J采用类似C语言中的printf函数的打印格式格式化日志信息

  • %m 输出代码中指定的消息
  • %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
  • %r 输出自应用启动到输出该log信息耗费的毫秒数
  • %c 输出所属的类目,通常就是所在类的全名
  • %t 输出产生该日志事件的线程名
  • %n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”
  • %d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss , SSS},输出类似:2002年10月18日 22 : 10 : 28 , 921
  • %F 输出日志事件的发生位置,包括类目名、发生的线程。举例:Testlog4.main(TestLog4.java:10)
  • %l 输出日志事件的发生位置在代码中的行数。举例:Testlog4.main(TestLog4.java:10 )

如:

log4j.appender.logRecord.layout.ConversionPattern=%d{yyyy-MM-dd HH\:mm\:ss} %C{8}@(%F\:%L)\:%m%n
2018-06-25 16:26:40 com.xk.edu.interception.LogRecordInterception@(LogRecordInterception.java:22):pre handle --->>> --->>>--- log4j.appender.logRecord.layout.ConversionPattern=%d{yyyy-MM-dd HH\:mm\:ss} (%L)\:%m%n
2018-06-25 16:30:39 (22):pre handle --->>> --->>>--- log4j.appender.logRecord.layout.ConversionPattern=%d{yyyy-MM-dd HH\:mm\:ss},%m%n
2018-06-25 16:35:16,pre handle --->>> --->>>---

6. 配置打印异常日志到一个单独的文件

把异常单独打印到一个单独的文件中,方便查看定位排查问题。

配置如下:

# 保存异常信息到单独文件
log4j.appender.ERR = org.apache.log4j.DailyRollingFileAppender
# 每天产生一个日志文件
log4j.appender.ERR.DatePattern='.'yyyy-MM-dd
# 异常日志文件名
log4j.appender.ERR.File=${catalina.base}/logs/error/adminError.log
log4j.appender.ERR.Append = true
# 是否立即输出
log4j.appender.ERR.ImmediateFlush=true
log4j.appender.ERR.Encoding=utf-8
# 只输出ERROR级别以上的日志!!!
log4j.appender.ERR.Threshold = ERROR
log4j.appender.ERR.layout = org.apache.log4j.PatternLayout
log4j.appender.ERR.layout.ConversionPattern = [%-5p][%d{yyyyMMdd HH:mm:ss,SSS}][%C{1}:%L] %m%n

上面配置中产生的error以上级别的日志会打印到logs/adminError.log中,明天会把今天产生的异常日志保存一个文件中,名称是adminError.log + 今天的日期,日期格式是根据log4j.appender.ERR.DatePattern定义的格式。

7. 日志过滤配置

如在6中把error级别以上的日志打印到异常文件中去了,如果不配置过滤,会在admin.log中打印info以上级别的日志,那样就重复打印了error以上级别的日志。

新FILE文件配置如下

# 打印日志到文件,排除error的日志
log4j.logger.FILE=INFO,FILE
log4j.appender.FILE=org.apache.log4j.RollingFileAppender
log4j.appender.FILE.File=${catalina.base}/logs/admin.log
log4j.appender.FILE.Encoding=utf-8
log4j.appender.R.MaxFileSize=100MB
log4j.appender.R.MaxBackupIndex=100
log4j.appender.FILE.DatePattern='.'yyyy-MM-dd
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
#log4j.appender.FILE.layout=org.apache.log4j.HTMLLayout
log4j.appender.FILE.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH\:mm\:ss} %C{8}@(%F\:%L)\:%m%n
# 不打印warn以上级别的日志
log4j.appender.FILE.filter.infoFilter = org.apache.log4j.varia.LevelRangeFilter
log4j.appender.FILE.filter.infoFilter.LevelMin=DEBUG
log4j.appender.FILE.filter.infoFilter.LevelMax=WARN

这样就只在admin.log中打印DEBUG级别到WARN级别的日志了。

8. 自定义logger的输出

如:

log4j.logger.com.xk.edu.interception.LogRecordInterception=INFO,logRecord

这样自定义了一个logger,不使用log4j.rootLogger。自定义的logger之间的日志是隔离的,如上配置的,只打印LogRecordInterception类下的日志。

如:

log4j.logger.com.xk.edu.dao=DEBUG

com.edu.dao包下的内容按DEBUG级别输出,因为dao包下是mapper文件,加上这一个配置就可以打印sql语句了。

9. 配置文件

以下贴出配置文件:

# ALL,DEBUG,INFO,WARN,ERROR,FATAL,OFF
LOG_LEVEL=INFO
log4j.rootLogger=${LOG_LEVEL},CONSOLE,FILE,ERR # 打印日志到控制台
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.Encoding=utf-8
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
#log4j.appender.CONSOLE.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss} %C{8}@(%F:%L):%m%n
log4j.appender.CONSOLE.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss} %C{1}@(%F:%L):%m%n # 打印日志到文件,排除error的日志
log4j.logger.FILE=INFO,FILE
log4j.appender.FILE=org.apache.log4j.RollingFileAppender
log4j.appender.FILE.File=${catalina.base}/logs/admin.log
log4j.appender.FILE.Encoding=utf-8
log4j.appender.R.MaxFileSize=100MB
log4j.appender.R.MaxBackupIndex=100
log4j.appender.FILE.DatePattern='.'yyyy-MM-dd
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
#log4j.appender.FILE.layout=org.apache.log4j.HTMLLayout
log4j.appender.FILE.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH\:mm\:ss} %C{8}@(%F\:%L)\:%m%n
# 不打印warn以上级别的日志
log4j.appender.FILE.filter.infoFilter = org.apache.log4j.varia.LevelRangeFilter
log4j.appender.FILE.filter.infoFilter.LevelMin=DEBUG
log4j.appender.FILE.filter.infoFilter.LevelMax=WARN # 保存异常信息到单独文件
log4j.appender.ERR = org.apache.log4j.DailyRollingFileAppender
# 每天产生一个日志文件
log4j.appender.ERR.DatePattern='.'yyyy-MM-dd
# 异常日志文件名
log4j.appender.ERR.File=${catalina.base}/logs/error/adminError.log
log4j.appender.ERR.Append = true
# 是否立即输出
log4j.appender.ERR.ImmediateFlush=true
log4j.appender.ERR.Encoding=utf-8
# 只输出ERROR级别以上的日志!!!
log4j.appender.ERR.Threshold = ERROR
log4j.appender.ERR.layout = org.apache.log4j.PatternLayout
log4j.appender.ERR.layout.ConversionPattern = [%-5p][%d{yyyyMMdd HH:mm:ss,SSS}][%C{1}:%L] %m%n # 输出拦截器的日志, 只输出LogRecordInterception类下的日志
log4j.logger.com.xk.edu.interception.LogRecordInterception=INFO,logRecord
log4j.appender.logRecord=org.apache.log4j.DailyRollingFileAppender
log4j.appender.logRecord.Append=true
# 是否立即输出
log4j.appender.logRecord.ImmediateFlush=true
# 一分钟产生一个日志文件
#log4j.appender.logRecord.DatePattern='.'yyyy-MM-dd-HH-mm
log4j.appender.logRecord.DatePattern='.'yyyy-MM-dd
log4j.appender.logRecord.Encoding=utf-8
log4j.appender.logRecord.layout=org.apache.log4j.PatternLayout
log4j.appender.logRecord.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH\:mm\:ss} %C{8}@(%F\:%L)\:%m%n # 打印 dao 下的 sql
log4j.logger.com.xk.edu.dao=DEBUG

参考:

http://www.blogjava.net/zJun/archive/2006/06/28/55511.html

https://blog.csdn.net/zxh317162782/article/details/51233704

https://blog.csdn.net/lingfenglangshao/article/details/78334147

log4j.properties配置说明的更多相关文章

  1. log4j.properties配置说明学习网址

    https://blog.csdn.net/wangzhaotongalex/article/details/51308802

  2. log4j.properties 日志文件的详细配置说明

    一.在一个web 项目中,使用tomcat 启动通常会在控制台输出出现一个警告信息: 通常为未添加 log4j.properties文件的原因. 二.下面以一个普通的maven项目为例说明一下 1. ...

  3. log4j.properties配置详解

    1.Loggers Loggers组件在此系统中被分为五个级别:DEBUG.INFO.WARN.ERROR和FATAL.这五个级别是有顺序的,DEBUG < INFO < WARN < ...

  4. log4j.properties配置

    一.日志:除了能记录异常信息,还可以记录程序正常运行时的关键信息. 使用log4j来进行日志文件记录经典步骤: 01.在项目中创建一个lib文件夹,然后将下载好的jar包copy到该文件夹下 02.对 ...

  5. log4j日志文件 log4j.xml log4j.properties配置

    1,导入log4j  jar包; 2,配置log4j.xml或log4j.properties文件; ------------------------------------------------- ...

  6. log4j.properties 使用

    一.参数意义说明 输出级别的种类 ERROR.WARN.INFO.DEBUG ERROR 为严重错误 主要是程序的错误 WARN 为一般警告,比如session丢失 INFO 为一般要显示的信息,比如 ...

  7. java 执行jar指定log4j.properties文件位置

    默认情况下,log4j.properties会被加载,并且这个文件需要在classpath根目录,当打包jar时,会打包打jar内部,当需要修改日志级别时,会比较麻烦 可以使用:java -jar - ...

  8. log4j.properties 详解与配置步骤

    一.log4j.properties 的使用详解 1.输出级别的种类 ERROR.WARN.INFO.DEBUGERROR 为严重错误 主要是程序的错误WARN 为一般警告,比如session丢失IN ...

  9. 转载:log4j.properties log4j.xml 路径问题

    自动加载配置文件: (1)如果采用log4j输出日志,要对log4j加载配置文件的过程有所了解.log4j启动时,默认会寻找source folder下的log4j.xml配置文件,若没有,会寻找lo ...

随机推荐

  1. CentOS 7配置MariaDB允许指定IP远程连接数据库

    防火墙 CentOS7 之前的防火墙是不一样的,比如你要添加3306端口: ## 全部 iptables -A INPUT -p tcp -m tcp --dport 3306 -j ACCEPT # ...

  2. iOS逆向开发(0):修改二进制代码与重签名 | hopper | codesigh

    小白:小程,你知道有些iOS程序是没人性的吗?老是不按我的意愿来运行! 小程:我怎么知道你的意愿就是有人性的? 本文解决一个问题:修改别人的二进制程序并运行起来. 让别人的程序按你的意愿来运行,文明一 ...

  3. python中执行该文件,就调用 mian 方法

    代码: test.py import student def main(): st = student.student(1001, 'tommy', 18) st.sing() st.dance() ...

  4. thinkphp自动验证分析

    thinkphp有一个自动验证的方法验证规则如下 array( array(验证字段1,验证规则,错误提示,[验证条件,附加规则,验证时间]), array(验证字段2,验证规则,错误提示,[验证条件 ...

  5. Ubuntu 安装网卡驱动

    搭建Linux平台的无线热点,需要无线网卡和驱动都要支持 AP. 试了下Ubuntu平台默认驱动并不支持AP模式,所以需要更换驱动,具体操作步骤如下: 1.找到自己网卡芯片的型号,由于我的环境是搭建在 ...

  6. Dubbo 源码分析系列之三 —— 架构原理

    1 核心功能 首先要了解Dubbo提供的三大核心功能: Remoting:远程通讯 提供对多种NIO框架抽象封装,包括"同步转异步"和"请求-响应"模式的信息交 ...

  7. MySQL高可用之组复制(4):详细分析组复制理论

    MySQL组复制系列文章: MySQL组复制大纲 MySQL组复制(1):组复制技术简介 MySQL组复制(2):配置单主模型的组复制 MySQL组复制(3):配置多主模型的组复制 MySQL组复制( ...

  8. Perl的输出:print、say和printf、sprintf

    print.printf和say都可以输出信息.print和say类似,print不自带换行符,say自带换行符,但要使用say,必须写use语句use 5.010;,printf像C语言的print ...

  9. Go基础系列:为select设置超时时间

    Go channel系列: channel入门 为select设置超时时间 nil channel用法示例 双层channel用法示例 指定goroutine的执行顺序 After() 谁也无法保证某 ...

  10. 关于EF中出现FOREIGNKEY约束可能会导致循环或多重级联路径的问题

    ef中,我们创建外键的时候需要注意,否则会出现标题所示问题. 例:有项目表,项目收藏表,用户表 项目表有如下字段:ProjectId,InputPersonId等 项目收藏表有如下字段:Project ...