常用日志框架及源码解析

573 阅读2分钟

这是我参与11月更文挑战的第4天,活动详情查看:2021最后一次更文挑战

常用日志框架

基础日志框架
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类,执行静态块 image.png image.png

调用getLog方法: 在这里插入图片描述

获取LogFactory对象:
在这里插入图片描述

image.png

image.png

image.png

image.png

image.png

image.png

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公共库:mvnrepository.com/ log4j.properties:blog.csdn.net/sinat_30185… log4j2与Servlet版本:www.cnblogs.com/bigbang92/p… log4j2.xml:www.cnblogs.com/hafiz/p/617… logback.xml:www.cnblogs.com/warking/p/5… springboot日志使用:blog.csdn.net/u010598111/…


------The End------

如果对您有用,或者您希望持续关注,可以在微信公众号中搜索【码路无涯】

感谢大家看到最后,文章持续更新!欢迎大家指出我的文章的不足之处,也欢迎大家关注、收藏+分享