常用日志框架及源码解析

本文介绍了常用的日志框架,包括log4j、log4j2、logback和JUL等,并详细解析了这些框架的配置方法及如何通过SLF4J进行集成。同时,还深入探讨了SLF4J作为日志接口的重要性及其与各种日志实现之间的桥接方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

常用日志框架

基础日志框架
log4j、log4j2、logback、JUL(java日志框架)
日志框架集成
JCL、SLF4J

基础日志框架

log4j

<!-- 引入log4j 对应log4j.properties --> 
<dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.17</version>
</dependency>

log4j2

<!-- 引入log4j2 对应log4j2.xml --> 
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-api</artifactId>
    <version>2.8.2</version>
</dependency>
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-core</artifactId>
    <version>2.8.2</version>
</dependency>

logback

<!-- 引入logback 对应logback.xml --> 
<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <version>1.2.3</version>
</dependency>

JUL(java日志框架)

日志框架集成

JCL(有自己默认的日志,总会打印出日志)

<!-- jcl -->
<dependency>
    <groupId>commons-logging</groupId>
    <artifactId>commons-logging</artifactId>
    <version>1.2</version>
</dependency>
源码分析

在这里插入图片描述
调用静态方法时加载LogFactory类,执行静态块
在这里插入图片描述
在这里插入图片描述
调用getLog方法:
在这里插入图片描述
获取LogFactory对象:
在这里插入图片描述
在这里插入图片描述在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
getInstance:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

SLF4J(日志接口,无默认日志,必须搭配日志桥接器)

  • slf4j只是一个日志标准,并不是日志系统的具体实现。理解这句话非常重要,slf4j只做两件事情:
    • 提供日志接口
    • 提供获取具体日志对象的方法
  • slf4j有自己的简单日志实现,但更重要的是作为一个门面,搭配其他日志实现
    slf4j-api的1.7.X版本与1.8.X版本获取ILoggerFactory的方式不同,桥接器实现也不同
    个人意见:目前推荐1.7.X,较为成熟
<!-- 只有slf4j-api依赖 -->
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
    <version>1.7.13</version>
</dependency>
源码分析

1、怎么找到所有的org/slf4j/impl/StaticLoggerBinder.class

在这里插入图片描述
在这里插入图片描述
2、由于存在多个org.slf4j.impl.StaticLogerBinder,这时会调用哪一个类的代码呢?
在这里插入图片描述
多个桥接器不会导致启动报错,
在这种情况下编译期间,编译器会选择其中一个StaticLoggerBinder.class进行绑定
编译期会调用在classpath中较早出现的org.slf4j.impl.StaticLogerBinder的代码.如在maven中,会调用在pom.xml中定义较靠前的桥接器的代码.

SLF4J日志桥接器
  1. logback是slf4j的native实现,不需要桥接包 只需要引入logback的jar包即可
  2. slf4j和log4j桥接包
<dependency>
   <groupId>org.slf4j</groupId>
   <artifactId>slf4j-log4j12</artifactId>
   <version>1.7.25</version>
</dependency>
  1. slf4j和log4j2桥接包
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-slf4j-impl</artifactId>
    <version>2.8.2</version>
</dependency>

<!--web工程需要包含log4j-web,非web工程不需要-->
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-web</artifactId>
    <version>2.8.2</version>
    <scope>runtime</scope>
</dependency>

<!--需要使用log4j2的AsyncLogger需要包含disruptor-->  
<dependency>  
     <groupId>com.lmax</groupId>  
     <artifactId>disruptor</artifactId>  
     <version>3.2.0</version>  
</dependency>
  1. slf4j和jul桥接包
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-jdk14</artifactId>
    <version>1.7.25</version>
</dependency>
  1. slf4j和jcl桥接包
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-jcl</artifactId>
    <version>1.7.25</version>
</dependency>
使用Slf4时如何桥接遗留的api
  1. log4j到slf4j的桥梁:log4j-over-slf4j-version.jar

  2. jcl到slf4j的桥梁:jcl-over-slf4j-version.jar

  3. jul到slf4j的桥梁:jul-to-slf4j-version.jar

  4. jcl到log4j2的桥梁:log4j-jcl

    例如:

<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>log4j-over-slf4j</artifactId>
    <version>1.7.25</version>
</dependency>

在这里插入图片描述

引用

maven公共库:https://mvnrepository.com/
log4j.properties:https://blog.youkuaiyun.com/sinat_30185177/article/details/73550377
log4j2与Servlet版本:https://www.cnblogs.com/bigbang92/p/log4j2_servlet.html
log4j2.xml:https://www.cnblogs.com/hafiz/p/6170702.html
logback.xml:http://www.cnblogs.com/warking/p/5710303.html
springboot日志使用:https://blog.youkuaiyun.com/u010598111/article/details/80556437

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值