百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

一文看懂Java日志框架体系_java 日志系统

csdh11 2025-02-20 15:08 16 浏览

1 简介

本文主要探究以下内容:

  • 介绍 Java 日志体系发展历程
  • 介绍 slf4j 日志门面,并梳理现有日志体系之间的关系及依赖

2 日志体系发展历程

在日常工作中可以看到项目中依赖的跟日志相关的 jar 包有很多,commons-logging.jar、log4j.jar、slf4j-api.jar、logback.jar 等等,眼花缭乱。要理清它们之间的关系,首先要从 Java Log 的发展历程说起。


1.log4j

log4j(作者 Ceki Gülcü)出来时就得到了广泛的应用,是 Java 日志事实上的标准,并成为了 Apache 的项目。

2.JUL

log4j 作为 Apache 基金会的一员,Apache 希望将 log4j 引入 jdk,不过被 sun 公司拒绝了。随后,sun 模仿 log4j,在 jdk1.4 中实现了 JUL 即 java.util.logging。

3.JCL

JUL 毕竟是 JDK 自带的,也有很多人用。同时还有其他日志组件,如 SimpleLog 等。这时如果有人想换成其他日志组件,如 log4j 换成 JUL,因为 API 完全不同,就需要改动代码。

为了将日志接口与实现解耦,Apache 推出了 JCL 即 Apache Commons Logging。JCL 只定义了一套日志接口,具体实现由 log4j 或 JUL 来完成。JCL 基于动态绑定来实现日志的记录,在使用时只需要用 JCL 定义的接口来编写代码即可,程序真正运行时会检查 classpath 中的具体实现,因此可以自由选择是由 log4j 还是 JUL 来实现日志功能。

4.slf4j&logback

这样看上去也挺美好的,但是 log4j 的作者(Ceki Gülcü)觉得 JCL 不好用,便接着开发出了 slf4j,它跟 JCL 类似,本身不替供日志具体实现,只对外提供接口或门面。目的就是为了替代 JCL。同时,还开发出 logback,一个比 log4j 拥有更高性能的组件,目的是为了替代 log4j。

5.log4j2

最后,Apache 为了避免 slf4j 和 logback 慢慢取代 JCL 和 log4j,推出了自己的反击之作 log4j2,相比 log4j 其性能获得了很大的提升。于是,我们就看到了如此多的日志框架并存的局面。

注:log4j2 目前是 Java 中最优秀的日志框架。

3 关系/依赖

大概了解了发展历程后,再详细看看它们之间的关系、依赖。

3.1 JCL

commons-logging 已经停止更新,最后的状态如下所示:

JCL 支持的日志组件不多,并且现在用的人越来越少,就不多讲了。

3.2 slf4j桥接到具体的日志框架

下图来自官方文档:

由上图可以看到 slf4j 几乎可以使用所有的具体日志框架。

上图释义如下:

  • 绿色的 application:应用层,向下可直接调用 slf4j 提供的 API
  • 浅蓝色的 abstract logging api:抽象 API 层
  • 深蓝色的 native implementation of slf4j-api:具体日志框架实现层,不需要适配器,本身已经实现了 slf4j-api
  • 湖蓝色的 adaptation layer:适配层,也就是桥接器
  • 灰色的 non-native implementation of slf4j-api:具体日志框架实现层,本身没有实现 slf4j-api,需要桥接器

第三层所有灰色的 jar 包都带有红框,这表示它们都直接实现了 slf4j-api,只是湖蓝色的桥接器对 slf4j-api 的实现并不是直接输出日志,而是转去调用别的日志框架声明的 API。

slf4j-simple.jar 和 slf4j-nop.jar 这两个不用多说,看名字就知道一个是 slf4j 的简单实现,一个是 slf4j 的空实现,平时用处也不大。而 logback 之所以也实现了 slf4j-api,就是因为 logback 和 slf4j 出自同一人之手。

3.3 具体的日志框架桥接到slf4j

除了从 slf4j 到其他日志框架的桥接器,还有另外一类桥接器,它们的作用跟上面的恰好相反,它们能将其它日志框架的 API 转调到 slf4j 的 API 上。

下图来自官方文档:

上图展示了能安全地从别的日志框架 API 转调回 slf4j 的三种情形。要想实现转调,方法就是图上列出的用特定的桥接器 jar 替换掉原有的日志框架 jar。

以左上角第一种情形为例:当 slf4j 底层使用的具体实现是 logback 时,上层允许桥接到 slf4j 的日志框架 API 有 log4j 和 JUL。JCL 虽然不是什么日志框架的具体实现,但它的 API 仍然能够被转调回 slf4j。

看完三种情形以后,会发现几乎所有其他日志框架的 API,包括 JCL 的 API,都能够随意的转调回 slf4j。但是这里要十分注意,有一个限制就是转调回 slf4j 的日志框架不能跟 slf4j 当前使用的具体日志实现框架相同。这个限制主要为了防止 A-to-B.jar 跟 B-to-A.jar 同时出现在类路径中,从而导致 A 和 B 一直不停地互相递归调用,最后导致堆栈溢出。

举个栗子,假设日志框架采用 slf4j+log4j。一个具体的日志操作过程如下:

首先调用 slf4j 的 API 接口,然后 slf4j 将请求转发给 slf4j-log4j12 来处理,这个是在编译期间静态绑定好的。最后 slf4j-log4j12 通过 log4j 来完成日志操作。此时项目中如果再加一个 log4j-over-slf4j 会怎样?如下图,日志请求会重新打回给 slf4j,从而形成一个环形。


作者:_dhengyi
链接:
https://juejin.im/post/6866800216440307725

相关推荐

pdf怎么在线阅读?这几种在线阅读方法看看

pdf怎么在线阅读?我们日常生活中经常使用到pdf文档。这种格式的文档在不同平台和设备上的可移植性,以及保留文档格式和布局的能力都很强。在阅读这种文档的时候,很多人会选择使用在线阅读的方法。在线阅读P...

PDF比对不再眼花缭乱:开源神器diff-pdf助你轻松揪出差异

PDF比对不再眼花缭乱:开源神器diff-pdf助你轻松揪出差异在日常工作和学习中,PDF文件可谓是无处不在。然而,有时我们需要比较两个PDF文件之间的差异,这可不是一件轻松的事情。手动逐页对比简直是...

全网爆火!580页Python编程快速上手,零基础也能轻松学会

Python虽然一向号称新手友好,但对完全零基础的编程小白来讲,总会在很长时间内,都对某些概念似懂非懂,每次拿起书本教程,都要从第一章看起。对于这种迟迟入不了门的情况,给大家推荐一份简单易懂的入门级教...

我的名片能运行Linux和Python,还能玩2048小游戏,成本只要20元

晓查发自凹非寺量子位报道|公众号QbitAI猜猜它是什么?印着姓名、职位和邮箱,看起来是个名片。可是右下角有芯片,看起来又像是个PCB电路板。其实它是一台超迷你的ARM计算机,不仅能够运...

由浅入深学shell,70页shell脚本编程入门,满满干货建议收藏

不会Linux的程序员不是好程序员,不会shell编程就不能说自己会Linux。shell作为Unix第一个脚本语言,结合了延展性和高效的优点,保持独有的编程特色,并不断地优化,使得它能与其他脚本语言...

真工程师:20块钱做了张「名片」,可以跑Linux和Python

机器之心报道参与:思源、杜伟、泽南对于一个工程师来说,如何在一张名片上宣告自己的实力?在上面制造一台完整的计算机说不定是个好主意。最近,美国一名嵌入式系统工程师GeorgeHilliard的名片...

《Linux 命令行大全》.pdf

今天跟大家推荐个Linux命令行教程:《TheLinuxCommandLine》,中文译名:《Linux命令行大全》。该书作者出自自美国一名开发者,兼知名Linux博客LinuxCo...

PDF转换是难题? 搜狗浏览器即开即看

由于PDF文件兼容性相当广泛,越来越多的电子图书、产品说明、公司文告、网络资料、电子邮件选择开始使用这种格式来进行内容的展示,以便给用户更好的再现原稿的细节,但需要下载专用阅读器进行转化才能浏览的问题...

彻底搞懂 Netty 线程模型

点赞再看,养成习惯,微信搜一搜【...

2022通俗易懂Redis的线程模型看完就会

Redis真的是单线程吗?我们一般说Redis是单线程,是指Redis的网络IO和键值对操作是一个线程完成的,这就是Redis对外提供键值存储服务的主要流程。Redis的其他功能,例如持久化、异步删除...

实用C语言编程(第三版)高清PDF

编写C程序不仅仅需要语法正确,最关键的是所编代码应该便于维护和修改。现在有很多介绍C语言的著作,但是本书在这一方面的确与众不同,例如在讨论C中运算优先级时,15种级别被归纳为下面两条原则:需要的...

手拉手教你搭建redis集群(redis cluster)

背景:最近需要使用redis存储数据,但是随着时间的增加,发现原本的单台redis已经不满足要求了,于是就倒腾了一下搭建redistclusterredis集群。好了,话不多说,下面开始展示:...

记录处理登录页面显示: HTTP Error 503. The service is unavailable.

某天一个系统的登录页面无法显示,显示ServiceUnavailableHTTPError503.Theserviceisunavailable,马上登录服务器上查看IIS是否正常。...

黑道圣徒杀出地狱破解版下载 免安装硬盘版

游戏名称:黑道圣徒杀出地狱英文名称:SaintsRow:GatOutofHell游戏类型:动作冒险类(ACT)游戏游戏制作:DeepSilverVolition/HighVoltage...

Exchange Server 2019 实战操作指南

...