SLF4J、Log4J、Log4J2、Logback之间是什么关系
创始人
2025-06-01 14:04:02
0

SLF4J ,全称Simple Logging Facade for Java, 即 “java的简单日志门面”

一,java世界中的日志框架

说明:前两项,即slf4j 和 jcl 是门面日志框架,是两种不同的日志框架接口,下面5项是实现;

好比slf4j 和 jcl是jdbc,而下面5项是各个数据库厂商实现的驱动。

slf4j、log4j、reload4j、log4j2、logback 的作者都是Ceki Gülcü;

jcl这套接口已经很久没更新,几乎不用了;

所以现在的java应用几乎都是使用slf4j做日志接口,在代码中都是面向slf4j的接口编程,

比如获取Logger对象都是导入org.slf4j包下的类:

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;public class LogbackTest {static Logger logger = LoggerFactory.getLogger(LogbackTest.class);static Logger logger2 = LoggerFactory.getLogger("com.baidu");
}

二,日志门面框架的好处

一个项目中,我们既要引入spring、又要引入mybatis、mybatis-plus等 ,还可能引入一些其他的jar包,这些jar包中都使用了日志,如果它们不是使用slf4j的接口,假设spring用log4j,mybatis用logback...... 那么这个项目就需要导入各种日志框架的jar包,并且更糟糕的是:

如果要修改spring日志的级别和日志文件的路径,就需要给spring建立一个日志的配置文件,

如果要修改mybatis日志的级别和日志文件的路径,就需要给mybatis建立一个日志的配置文件,

。。。。。。。。。。想想就觉得不太妥当。

而有了slf4j, spring和mybatis都使用slf4j的接口进行编程,我们在使用这两个框架时,想使用任意一个实现了slf4j的日志实现框架都可以,只需要一个日志配置文件,就能同时管理项目中所有jar包内的日志级别、输出文件的路径、日志格式等。

三,什么是适配层

有些日志框架并没有直接实现slf4j,而是用一个适配层(单独一个jar包) 去实现slf4j,然后由适配层调用具体的实现,这样的好处是什么?

我想这个作者是不是不光只想实现slf4j,可能怕日后再出一个很牛的日志门面框架,他想实现那个新框架就只用再写个适配层,而不用改写所有的实现代码吧。

如果考虑适配层,整个日志输出的流程如下:

四,各种日志框架实现关系

日志框架的具体实现与适配层:

五,案例分析

1,slf4j 采用logback的实现(无适配层),工作过程如下:

1.1 在程序中使用slf4j的api获取logger对象,并输出logger

1.2,引入slf4j真正的实现,这里采用logback

1.3,运行结果:

2,slf4j 采用 reload4j 的实现(有适配层),工作过程如下:

2.1 在程序中使用slf4j的api获取logger对象,并输出logger

此步骤与上面一样,略。

2.2 引入依赖

2.3 增加配置文件,不加也可以

2.4 运行结果:

3,总结使用流程

六,slf4J 发现实现类的原理

slf4j 它是怎么知道它的实现类是哪个,是怎么知道实现类的全类名,然后创建它的实例进行使用的呢?

slf4j 1.7.x 及之前,通过JVM类加载机制,发现底层具体的实现类;

slf4j 1.8.x 开始, 通过SPI机制,发现底层具体的实现类;

如果对spi机制不熟悉,看https://blog.csdn.net/weixin_43833851/article/details/129699586

1,slf4j 1.7.x 发现实现类的过程分析

slf4j 的代码中,通过 org.slf4j.impl.StaticLogggerBinder.getSingleton() 获取实现类对象,

但是slf4j 中并没有 org.slf4j.impl.StaticLogggerBinder 这个类,

谁想实现slf4j,谁就在自己的代码里面写一个 org.slf4j.impl.StaticLogggerBinder 类,定义getSingleton()方法返回实现类对象。

比如阿里想写个slf4j的实现,包名肯定是com.alibaba开头,但是还得建个 org.slf4j.impl包,里面放一个StaticLogggerBinder 类。

那slf4j 中没有 org.slf4j.impl.StaticLogggerBinder 这个类是怎么编译通过的呢?

它为了能编译通过,先在代码里面定义这个类,打好jar包后,删除jar包里面的这个类的class文件。

源码如下:

如果一个应用里面引入了多个 slf4j的实现,那么就会有多个 org.slf4j.impl.StaticLogggerBinder 这个类,这时会怎么办呢?

先读取哪个就用哪个,其他忽略,不同虚拟机(如hotspot、JRocket等)可能加载顺序不同,所以在不同虚拟机上可能加载的实现框架不一样。

缺点:

1,对slf4j而言,为了能编译通过,需要写一个org.slf4j.impl.StaticLogggerBinder 类,打成jar包后再删除这个类,感觉怪怪的;

2,对实现者而言,还要额外建个org.slf4j.impl包,里面放一个StaticLogggerBinder 类,比如上面举例的阿里想写个slf4j的实现,就觉得很别扭。

2,slf4j 1.8.x 发现实现类的过程分析

使用SPI机制得到实现类对象:

即由slf4j的实现者,在自己jar包的META-INF/services下定义一个org.slf4j.SLF4JServiceProvider 的文件,文件内写上实现类的全限定名,

slf4j通过java.util.ServiceLoader类解析META-INF/services下所有文件从而获取到实现类对象

相关内容

热门资讯

日常等车时看到的行业细节 干了五年户外广告投放,养成了一个职业病:但凡路过公交候车亭,总会多看两眼——不是看广告好不好看,而是...
黄金回收行业标准制定有哪些核心... 贵金属回购市场的需求背景 近年来随着黄金投资和消费市场的发展,黄金回收相关需求持续攀升。不同群体的诉...
全球黑色星期二!AI交易“崩盘... 【导读】AI交易为何“崩盘”? 中国基金报记者 泰勒 大家,你们今天还好吗?! AI交易在全球范围内...
原创 6... 年初抢金条的人还在站岗,如今金店柜台前冷冷清清 黄金又跌了。 6月23日,伦敦现货黄金价格日内急跌逾...
狂融294亿美元!SK海力士冲... 韩国股市再度迎来重磅消息。 周三,韩国存储芯片龙头SK海力士宣布,计划在7月10日登陆纳斯达克,通过...
比特币跌破6万!AI吸走资金、... 比特币正在为机构化转型付出代价。散户买盘萎缩、ETF资金持续外流、企业持仓者潜在抛售压力上升,加之A...
原创 默... 欧洲近期试图复刻1985年广场协议的剧本,德国总理默茨呼吁欧盟27国联合行动,要求中国签订类似协议以...
怎么选 泛娱乐赛道直播公司孵化... 泛娱乐直播创业的行业发展背景 近年来泛娱乐直播赛道持续保持增长态势,据公开数据资料显示,2024年国...
原创 腰... 最近黄金市场凉得彻底。各大品牌足金饰品克价跌破1300元关口,北京菜百6月21日报价已经掉到1260...
ST中装:公司主要银行账户已全... 证券之星消息,ST中装(002822)06月24日在投资者关系平台上答复投资者关心的问题。 投资者提...
2026年开窗机行业趋势与战略... 一、开篇引言:市场格局重塑下的选择逻辑 步入2026年,全球建筑智能化与绿色节能政策的叠加驱动,使开...
资金全面转向科技,传统消费企业... 近期 A 股出现明显风格切换,老牌消费资金持续流出,机构与传统上市公司纷纷加码半导体、算力赛道。 先...
合肥保利翡翠天奕具体交房时间是... 对于众多购房者而言,“合肥保利翡翠天奕具体交房时间是什么时候?能按时交房吗?”是心中最关切的问题。根...
港股风向标|恒指连续杀跌后企稳... 财联社6月24日讯(编辑 冯轶)今日港股短线企稳,三大指数集体收涨。截至收盘,恒生指数涨0.33%,...
瑞众人寿达州中支被罚17万,涉... 蓝鲸新闻6月24日讯,近日,国家金融监督管理总局达州监管分局发布行政处罚决定书,剑指瑞众人寿保险有限...
美国最担心的事还是来了,中国加... 最近这段时间,国际金融圈子里有一笔账,算得各家央行心里都不太踏实。 截至2026年春季,美国国债总规...
马斯克,不是万亿富豪了 资产历史性超过万亿美元不到两周,特斯拉、SpaceX掌门人埃隆·马斯克的身价近日快速下跌。 据中新经...
突发!金价跌破4000美元,近... 每经记者:杜宇 记者|杜宇 编辑|何小桃 杜恒峰 校对|金冥羽 金银价格大跳水。 6月24日晚,现货...
粗粮吃越多越好?很多糖友吃错升... 控糖圈一直流传多吃粗粮稳血糖,不少糖友直接三餐全吃粗粮、顿顿杂粮,不仅胃胀消化不良,餐后血糖反而不降...
持续大跌!刚刚,黄金跌破400... 潮新闻客户端 记者 吴恩慧 6月24日,贵金属再次大跌。 截至发稿时,现货黄金大跌近3%,跌破400...