常用日志框架及源码解析

常用日志框架及源码解析

  • 常用日志框架
    • 基础日志框架
      • log4j
      • log4j2
      • logback
      • JUL(java日志框架)
    • 日志框架集成
      • JCL(有自己默认的日志,总会打印出日志)
        • 源码分析
      • SLF4J(日志接口,无默认日志,必须搭配日志桥接器)
        • 源码分析
        • SLF4J日志桥接器
        • 使用Slf4时如何桥接遗留的api
  • 引用

常用日志框架

基础日志框架
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类,执行静态块
常用日志框架及源码解析_第1张图片
常用日志框架及源码解析_第2张图片
调用getLog方法:
在这里插入图片描述
获取LogFactory对象:
常用日志框架及源码解析_第3张图片
常用日志框架及源码解析_第4张图片常用日志框架及源码解析_第5张图片
常用日志框架及源码解析_第6张图片
常用日志框架及源码解析_第7张图片
常用日志框架及源码解析_第8张图片
常用日志框架及源码解析_第9张图片
getInstance:
常用日志框架及源码解析_第10张图片
常用日志框架及源码解析_第11张图片
常用日志框架及源码解析_第12张图片
常用日志框架及源码解析_第13张图片
常用日志框架及源码解析_第14张图片

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

在这里插入图片描述
常用日志框架及源码解析_第15张图片
2、由于存在多个org.slf4j.impl.StaticLogerBinder,这时会调用哪一个类的代码呢?
常用日志框架及源码解析_第16张图片
多个桥接器不会导致启动报错,
在这种情况下编译期间,编译器会选择其中一个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>

常用日志框架及源码解析_第17张图片

引用

maven公共库:https://mvnrepository.com/
log4j.properties:https://blog.csdn.net/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.csdn.net/u010598111/article/details/80556437

你可能感兴趣的:(后台)