Log4j2 分析与实践 - 认识 Log4j2

本贴最后更新于 2530 天前,其中的信息可能已经物是人非

Apache Log4j2 是 Log4j1 的升级版,与 Log4j1 相比,Log4j2 有着重大的改进;Log4j2 也提供了 Logback 特有的很多功能,同时修复了 Logback(另一款日志框架)框架存在的一些固有问题。

API 分离
Log4j2 的 API 和实现已经分开,有利于应用开发者清楚他们可以使用的类和方法。

性能改进
Log4j2 包含了基于 LMAX Disruptor(高性能线程间消息通信库)的下一代 Asynchronous Loggers。在多线程环境下,Asynchronous Loggers 的吞吐量是 Log4j1 和 Logback 的 18 倍,而延迟时间也要低一个数量级。

支持多个 API
Log4j2 不但有着优异的性能,而且还提供了 Log4j1.2、SLF4J、Common Logging 和 java.util.logging(JUL)的 API。

自动配置加载
跟 Logback 相同的是,Log4j2 能够在配置修改之后自动重新加载配置。跟 Logback 不同的是,自动加载配置的过程中,Log4j2 不会丢失日志事件。

高级过滤
跟 Logback 一样,Log4j2 可以基于上下文数据、标签、正则表达式和日志事件中的其它元素进行过滤。我们可以在所有事件被传到 Loggers 或者 Appenders 之前指定过滤器,以此来决定哪些事件可以继续进入下一步。而且,过滤器可以和 Loggers 关联。与 Logback 不同的是,你可以在任何场景中使用一个公共的过滤器。

插件架构
Log4j2 使用插件模式来配置组件。因此,你不必写代码创建或配置 Appender、Layout、Pattern Converter 等,当配置引用到它们时,Log4j2 会自动识别并使用这些插件。

属性支持
你可以在配置中引用属性,Lo4j2 会自动替换它们,或者 Log4j2 会将它们传递到底层的组件并解析它们。属性来源于配置文件、系统属性、环境变量、ThreadContext Map 和事件中的数据。用户也可以通过新增 Lookup 插件来提供自定义的属性提供者。

Java Lambda 支持
以前,若打印的日志消息过于消耗资源,你通常会在打印日志前,显示地检查一下请求的日志级别是否启用。运行在 Java8 上的代码,就可以受益于 Log4j2 的 lambda 支持。如果请求的日志级别没有启用,Log4j 将不会解析 lambda 表达式,同时也会减少打印日志的代码量。

JAVA 版本要求
Log4j 2.4 及以上的版本要求 Java7,Log4j 2.0-alpha1 要求 Java6.

下载与安装
官方下载地址:https://logging.apache.org/log4j/2.x/download.html,下载构建好的包 apache-log4j-2.8.2-bin.tar.gz,也可以下载源码来研究 apache-log4j-2.8.2-src.tar.gz,后续文章的分析中会用到源码。如果用的 IDE 支持自动下载源码的话,就不需要在这里下载源码了。
如果你使用的是 Maven 构建工具,加入以下依赖即可:
<dependency>
<groupId>org.apache.logging.log4j
<artifactId>log4j-api
<version>2.8.2
</dependency>
<dependency>
<groupId>org.apache.logging.log4j
<artifactId>log4j-core
<version>2.8.2
</dependency>

配置到工程中
为了使用 Log4j2,你需要确保 API 和 CORE 包均已添加到应用 classpath 路径下。示例:
log4j-api-2.8.2.jar
log4j-core-2.8.2.jar

变更说明
Log4j2 与以前的版本是不兼容的,当你打算升级已有项目到 log4j2 之前,请牢记以下几点:
(1)Log4j2.4 及以上版本需要 Java7,2.0-alpha1 至 2.3 需要 Java6。
(2)XML 配置已被简化,且与 Log4j1.x 不兼容。
(3)从 2.4 开始支持 log4j2.properties 文件,但与 Log4j1.x 不兼容。
(4)支持使用 JSON 和 YAML 进行配置,但这些格式需要额外的依赖。
(5)尽管 Log4j2 不直接支持 Log4j1,但在从 Log4j1 升级到 Log4j2 的过程中,使用提供的兼容包可以减少代码的修改。

  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3168 引用 • 8207 回帖
  • Log4j

    Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。

    20 引用 • 18 回帖 • 43 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    39 引用 • 24 回帖
  • HTML

    HTML5 是 HTML 下一个的主要修订版本,现在仍处于发展阶段。广义论及 HTML5 时,实际指的是包括 HTML、CSS 和 JavaScript 在内的一套技术组合。

    103 引用 • 294 回帖
  • 创造

    你创造的作品可能会帮助到很多人,如果是开源项目的话就更赞了!

    173 引用 • 990 回帖 • 1 关注
  • 旅游

    希望你我能在旅途中找到人生的下一站。

    85 引用 • 895 回帖
  • GitBook

    GitBook 使您的团队可以轻松编写和维护高质量的文档。 分享知识,提高团队的工作效率,让用户满意。

    3 引用 • 8 回帖
  • JetBrains

    JetBrains 是一家捷克的软件开发公司,该公司位于捷克的布拉格,并在俄国的圣彼得堡及美国麻州波士顿都设有办公室,该公司最为人所熟知的产品是 Java 编程语言开发撰写时所用的集成开发环境:IntelliJ IDEA

    18 引用 • 54 回帖 • 1 关注
  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    164 引用 • 594 回帖
  • 服务

    提供一个服务绝不仅仅是简单的把硬件和软件累加在一起,它包括了服务的可靠性、服务的标准化、以及对服务的监控、维护、技术支持等。

    41 引用 • 24 回帖 • 5 关注
  • 外包

    有空闲时间是接外包好呢还是学习好呢?

    26 引用 • 232 回帖 • 6 关注
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 559 关注
  • 禅道

    禅道是一款国产的开源项目管理软件,她的核心管理思想基于敏捷方法 scrum,内置了产品管理和项目管理,同时又根据国内研发现状补充了测试管理、计划管理、发布管理、文档管理、事务管理等功能,在一个软件中就可以将软件研发中的需求、任务、bug、用例、计划、发布等要素有序的跟踪管理起来,完整地覆盖了项目管理的核心流程。

    5 引用 • 15 回帖 • 222 关注
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 636 关注
  • 电影

    这是一个不能说的秘密。

    120 引用 • 597 回帖
  • Ngui

    Ngui 是一个 GUI 的排版显示引擎和跨平台的 GUI 应用程序开发框架,基于
    Node.js / OpenGL。目标是在此基础上开发 GUI 应用程序可拥有开发 WEB 应用般简单与速度同时兼顾 Native 应用程序的性能与体验。

    7 引用 • 9 回帖 • 345 关注
  • Ant-Design

    Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。

    17 引用 • 23 回帖 • 2 关注
  • golang

    Go 语言是 Google 推出的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性。谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发 Go,是因为过去 10 多年间软件开发的难度令人沮丧。Go 是谷歌 2009 发布的第二款编程语言。

    492 引用 • 1383 回帖 • 375 关注
  • 倾城之链
    23 引用 • 66 回帖 • 100 关注
  • Mobi.css

    Mobi.css is a lightweight, flexible CSS framework that focus on mobile.

    1 引用 • 6 回帖 • 697 关注
  • GitHub

    GitHub 于 2008 年上线,目前,除了 Git 代码仓库托管及基本的 Web 管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。正因为这些功能所提供的便利,又经过长期的积累,GitHub 的用户活跃度很高,在开源世界里享有深远的声望,并形成了社交化编程文化(Social Coding)。

    207 引用 • 2031 回帖
  • 七牛云

    七牛云是国内领先的企业级公有云服务商,致力于打造以数据为核心的场景化 PaaS 服务。围绕富媒体场景,七牛先后推出了对象存储,融合 CDN 加速,数据通用处理,内容反垃圾服务,以及直播云服务等。

    25 引用 • 215 回帖 • 165 关注
  • 链滴

    链滴是一个记录生活的地方。

    记录生活,连接点滴

    131 引用 • 3639 回帖
  • flomo

    flomo 是新一代 「卡片笔记」 ,专注在碎片化时代,促进你的记录,帮你积累更多知识资产。

    3 引用 • 80 回帖 • 2 关注
  • 博客

    记录并分享人生的经历。

    270 引用 • 2386 回帖
  • Lute

    Lute 是一款结构化的 Markdown 引擎,支持 Go 和 JavaScript。

    25 引用 • 191 回帖 • 21 关注
  • Linux

    Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 Unix 的多用户、多任务、支持多线程和多 CPU 的操作系统。它能运行主要的 Unix 工具软件、应用程序和网络协议,并支持 32 位和 64 位硬件。Linux 继承了 Unix 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    915 引用 • 931 回帖
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖
  • abitmean

    有点意思就行了

    22 关注