http://blog.csdn.net/lrenjundk/article/details/8178875

1. Log4j2的导入

首先到http://logging.apache.org/log4j/2.x/download.html 上下载最新的log4j2的jar包,然后再eclipse中加入log4j-api-2.0-beta2.jar和log4j-core-2.0- beta2.jar,需要注意的是不要将所有jar都导入工程造成不必要的混乱。

2. 测试用例

log4j 2.0的使用非常简单,只要用LogManager的getLogger函数获取一个logger,就可以使用logger记录日志,代码如下:

[java] view plaincopy
  1. import org.apache.logging.log4j.LogManager;
  2. import org.apache.logging.log4j.Logger;
  3. public class HelloLog4j {
  4. private static Logger logger = LogManager.getLogger("HelloLog4j");
  5. public static void main(String[] args) {
  6. MyApplication myApplication =  new MyApplication();
  7. logger.entry();
  8. logger.info("Hello, World!");
  9. myApplication.doIt();
  10. logger.error("Hello, World!");
  11. logger.exit();
  12. }
  13. }
[java] view plaincopy
  1. import org.apache.logging.log4j.LogManager;
  2. import org.apache.logging.log4j.Logger;
  3. public class MyApplication {
  4. static Logger logger = LogManager.getLogger(MyApplication.class.getName());
  5. public boolean doIt() {
  6. logger.entry();   //Log entry to a method
  7. logger.error("Did it again!");   //Log a message object with the ERROR level
  8. logger.exit();    //Log exit from a method
  9. return false;
  10. }
  11. }

运行程序,输出结果为:

[plain] view plaincopy
  1. 16:10:28.672 [main] ERROR MyApplication - Did it again!
  2. 16:10:28.672 [main] ERROR HelloLog4j - Hello, World!

注意到,输出的log都是在ERROR level上的,log4j定义了8个级别的log(除去OFF和ALL,可以说分为6个级别),优先级从高到低依次为:OFF、FATAL、ERROR、WARN、INFO、DEBUG、TRACE、 ALL。如果将log level设置在某一个级别上,那么比此级别优先级高的log都能打印出来。例如,如果设置优先级为WARN,那么OFF、FATAL、ERROR、WARN 4个级别的log能正常输出,而INFO、DEBUG、TRACE、 ALL级别的log则会被忽略。从我们实验的结果可以看出,log4j默认的优先级为ERROR或者WARN(实际上是ERROR)。

3. 配置文件

log4j是apache的一个开源项目,在写这篇博客的时候已经发布了2.0的beta版本,首先需要注意的是,log4j 2.0与以往的1.x有一个明显的不同,其配置文件只能采用.xml, .json或者 .jsn。在默认情况下,系统选择configuration文件的优先级如下:(classpath为scr文件夹)

  1. classpath下名为 log4j-test.json 或者log4j-test.jsn文件
  2. classpath下名为 log4j2-test.xml
  3. classpath下名为 log4j.json 或者log4j.jsn文件
  4. classpath下名为 log4j2.xml
        必须注意.xml 文件的文件名为log4j2,这里让我纠结了一个下午,系统一直找不到配置文件,最后发现是文件名里面少了一个2。下面以log4j2.xml为例来介绍log4j的配置。
[html] view plaincopy
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <configuration status="OFF">
  3. <appenders>
  4. <Console name="Console" target="SYSTEM_OUT">
  5. <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
  6. </Console>
  7. </appenders>
  8. <loggers>
  9. <root level="trace">
  10. <appender-ref ref="Console"/>
  11. </root>
  12. </loggers>
  13. </configuration>
首先介绍loggers标签,用于定义logger的lever和所采用的appender,其中appender-ref必须为先前定义的 appenders的名称,例如,此处为Console。那么log就会以appender所定义的输出格式来输出log。
root标签为log的默认输出形式,如果一个类的log没有在loggers中明确指定其输出lever与格式,那么就会采用root中定义的格式。例如以下定义:
[html] view plaincopy
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <configuration status="OFF">
  3. <appenders>
  4. <Console name="Console" target="SYSTEM_OUT">
  5. <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
  6. </Console>
  7. </appenders>
  8. <loggers>
  9. <logger name="com.relin.HelloLog4j" level="error" additivity="false">
  10. <appender-ref ref="Console"/>
  11. </logger>
  12. <root level="trace">
  13. <appender-ref ref="Console"/>
  14. </root>
  15. </loggers>
  16. </configuration>

此时,HelloLog4j则会在error级别上输出log,而其他类则会在trace级别上输出log。需要注意的是 additivity选项,如果设置为true(默认值)则HelloLog4j的log会被打印两次,第二次打印是由于HelloLog4j同时也满足 root里面定义的trace

4. 其他特征

[html] view plaincopy
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <configuration status="error">
  3. <appenders>
  4. <Console name="Console" target="SYSTEM_OUT">
  5. <ThresholdFilter level="trace" onMatch="ACCEPT" onMismatch="DENY"/>
  6. <PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
  7. </Console>
  8. <File name="log" fileName="target/test.log" append="false">
  9. <PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
  10. </File>
  11. <RollingFile name="RollingFile" fileName="logs/app.log"
  12. filePattern="logs/$${date:yyyy-MM}/app-%d{MM-dd-yyyy}-%i.log.gz">
  13. <PatternLayout pattern="%d{yyyy.MM.dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
  14. <SizeBasedTriggeringPolicy size="500 MB" />
  15. </RollingFile>
  16. </appenders>
  17. <loggers>
  18. <root level="trace">
  19. <appender-ref ref="RollingFile"/>
  20. <appender-ref ref="Console"/>
  21. </root>
  22. </loggers>
  23. </configuration>

扩展组件

1,ConsoleAppender

输出结果到System.out或是System.err。

2,FileAppender

输出结果到指定文件,同时可以指定输出数据的格式。append=“false”指定不追加到文件末尾

3,RollingFileAppender

自动追加日志信息到文件中,直至文件达到预定的大小,然后自动重新生成另外一个文件来记录之后的日志。

过滤标签

1,ThresholdFilter

用来过滤指定优先级的事件。

2,TimeFilter

设置start和end,来指定接收日志信息的时间区间。

转载于:https://www.cnblogs.com/backpacker/archive/2012/12/10/2812100.html

log4j2 使用详解 (转)相关推荐

  1. Log4j2使用详解

    日志框架简单比较(slf4j.j.u.l.log4j.logback.log4j2 ) slf4j:slf4j是对所有日志框架制定的一种规范.标准.接口,并不是一个框架的具体的实现,因为接口并不能独立 ...

  2. log4j2内容详解

    log4j2 日志用于帮助开发查漏补缺,经常使用,但是适合自己的一套日志结构才能更快的帮助自己进行阅读以及定位. 解读 <?xml version="1.0" encodin ...

  3. Log4j2配置详解

    一.背景 最近由于项目的需要,需要将日志全部迁移成 log4j2 版本,之前对于项目日志的配置总是似懂非懂,最近详细整理了下知识点,本文就作为一个记录来详细记录一下 log4j2 配置的相关知识点. ...

  4. log4j2配置文件log4j2.xml详解

    一.配置全解 1.关于配置文件的名称以及在项目中的存放位置 log4j 2.x版本不再支持像1.x中的.properties后缀的文件配置方式,2.x版本配置文件后缀名只能为".xml&qu ...

  5. log4j2 配置详解及使用范例

    最近项目需求需要将log4j1.2 升级到log4j2,摸索了好久,得出一点经验给大家分享. 1.log4j2 官网下载最新jar包(目前log2j2都是beta版) 导入入log4j-api-2.0 ...

  6. log4j2 pattern详解

    版权声明:本文为博主http://blog.csdn.net/zhu19774279原创文章,未经博主允许不得转载. https://blog.csdn.net/zhu19774279/article ...

  7. Java日志体系日志门面(Slf4j)日志实现(Log4j、Log4j2)详解

    1.背景 近日发生两次因日志使用不当导致的线上问题: 1.应用明明配置了info日志级别,却打印大量的debug日志,导致磁盘IO较高,很快就报磁盘空间不足告警 2.应用服务启动后报StackOver ...

  8. Apache Log4j2详解,【高级Java架构师系统学习

    []( )引用依赖 在一般项目中使用Log4j2至少需要引用log4j-api-2.x和log4j-core-2.x这两个jar包. org.apache.logging.log4j log4j-co ...

  9. SpringBoot整合Log4j2以及配置详解

    文章目录 标题SpringBoot整合Log4j2以及配置详解 1.加入依赖 2.在src.java.main.resources目录下创建log4j2.xml文件 log4j2.xml文件内容如下: ...

  10. log4j2的使用及配置详解

    前言 众所周知,最近log4j被测出了漏洞,先是log4j2被测出了漏洞,漏洞影响范围为Log4j2.x <= 2.14.1:后来又被测出log4j1.X也有漏洞,范围为整个1.X版本.我们项目 ...

最新文章

  1. python标准库学习4
  2. 网络负载均衡相关技术-服务器负载
  3. 沼泽鳄鱼_SSL2511_矩阵乘法
  4. SAP ABAP用户锁定标识USR02-UFLAG
  5. 技术资料,老吴的博客 很好的 技术博客 里面有很多资料 书籍或者软件安装包...
  6. 平均交付时长减少五天!腾讯TAPD助力企业高效交付!
  7. Python——异常基础
  8. 使用shell做进制转换
  9. kindeditor自定义插件插入视频代码
  10. PyQt上位机软件开发简介
  11. 站内文章被百度收录的方法
  12. 计算机毕业设计(附源码)python-志愿者管理系统
  13. php服务器状态监测,PHP网站状态在线监控源码
  14. TAPD使用方法学习
  15. 使用scrapy图片管道下载图片
  16. 基于51单片机土壤湿度检测及自动浇花系统(带时间显示)
  17. SaaS 前世今生:老树开新花
  18. 学习Node.js笔记(一)
  19. 高通平台msm8953 Linux DTS(Device Tree Source)设备树详解之二(DTS设备树匹配过程)
  20. bzoj2245 [SDOI2011]工作安排

热门文章

  1. A. httpd常见的几个操作
  2. C++入门经典-例3.9-使用嵌套表达式判断一个数是否是3和5的整数倍
  3. [转载]git 设置第一次输入密码之后不用输入密码
  4. 合并两个LMDB文件
  5. 考研英语作文:环保呼吁信
  6. freeldr 如何调用_BootMain的
  7. Rxjs初体验:制作语音测试工具
  8. Qt-5.10.1 Windows MinGW 下QwtPlot3D的编译及其示例的运行
  9. 【JWT】JWT+HA256加密 Token验证
  10. 【探索PowerShell 】【七】变量