美文网首页
日志门面SLF4J

日志门面SLF4J

作者: Tinyspot | 来源:发表于2022-07-13 00:24 被阅读0次

SLF4J

  • www.slf4j.org/
  • 核心依赖 slf4j-api
  • 日志门面,虽然底层的日志实现变了,但原代码不必改变
image.png

slf4j-core: 日志门面

<dependency>
     <groupId>org.slf4j</groupId>
     <artifactId>slf4j-api</artifactId>
     <version>1.7.32</version>
 </dependency>

2. 三类

  • unbound
  • logback 和 simple(包括 nop) 在 sl4j 时间线之后,完全遵循 sl4j 的实现
  • log4j, JUL 在 sl4j 之间就出现,适配桥接技术

2.1 simple

  • 自带的简单日志实现
  • slf4j-simple.jar
<!-- 加上 slf4j-api 依赖-->
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-simple</artifactId>
    <version>1.7.32</version>
    <scope>test</scope>
</dependency>

2.2 SLF4J bind JUL

  • JUL 是 Java 原生日志框架,无需导入依赖
  • 需绑定一个适配器 slf4j-jdk14
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-jdk14</artifactId>
    <version>1.7.32</version>
</dependency>

2.3 SLF4J bind Log4j

  • 需要绑定一个适配器 slf4j-log4j12
  • log4j.jar
  • log4j.properpties
<!-- 加上 slf4j-api 依赖-->
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-log4j12</artifactId>
    <version>1.7.32</version>
</dependency>
<dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.17</version>
</dependency>

2.4 SLF4J bind Logback

  • jar logback-classic, logback-core
  • pom.xml 因依赖传递性,只需导入 logback-classic
<!-- 加上 slf4j-api 依赖-->
<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <version>1.2.3</version>
</dependency>

2.5 SLF4J bind Log4j 2

  • log4j-slf4j-impl 适配器
  • slf4j借助log4j-slf4j-impl适配层,连接到log4j-api上,log4j-api再连接到log4j-core上
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-slf4j-impl</artifactId>
    <version>2.17.1</version>
</dependency>
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-api</artifactId>
    <version>2.17.1</version>
</dependency>
<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-core</artifactId>
    <version>2.17.1</version>
</dependency>

3. 示例

SLF4J: Class path contains multiple SLF4J bindings. 表明同时出现了多个日志实现,默认是先导入的先实现

import org.slf4j.LoggerFactory;
private static final Logger logger = LoggerFactory.getLogger(Demo.class);
private Logger logger = LoggerFactory.getLogger(Demo.class.getName());
// protected 子类可以直接使用
protected final Logger log = LoggerFactory.getLogger(this.getClass());

5. SLF4J 源码分析

// LoggerFactory#getLogger(java.lang.Class<?>)
Logger logger = getLogger(clazz.getName());
public static Logger getLogger(String name) {
  ILoggerFactory iLoggerFactory = getILoggerFactory();
  return iLoggerFactory.getLogger(name);
}
private final static void performInitialization() {
  bind();
  if (INITIALIZATION_STATE == SUCCESSFUL_INITIALIZATION) {
    versionSanityCheck();
  }
}
// org.slf4j.LoggerFactory#bind
StaticLoggerBinder.getSingleton();

References

相关文章

  • 主流日志框架

    一、日志门面 1.1 简单日志门面SLF4J SLF4J,即简单日志门面(Simple Logging Facad...

  • Facade Design Pattern

    门面模式应用 SLF4J,即简单日志门面(Simple Logging Facade for Java),不是具体...

  • SLF4J: Failed to load class "org

    使用slf4j报错 slf4j即简单日志门面(Simple Logging Facade for Java),不是...

  • 日志-slf4j

    本篇主要介绍slf4j。slf4j全称:Simple Logging Facade for Java简单日志门面(...

  • spring mvc日志:slf4j+logback

    commons与slf4j commons-logging和slf4j都是日志门面库, 提供统一日志接口, 再由实...

  • springboot日志系统

    日志系统种类 springboot通过slf4j门面支持多种日志系统:主要包含 JavaLoggingSystem...

  • logback、log4j、slf4j三者区别

    1、整体介绍 slf4j(Simple logging Facade for Java) 简单日志门面,日志系统的...

  • 理解slf4j

    概念 SLF4J,即简单日志门面(Simple Logging Facade for Java),不是具体的日志解...

  • 日志输出规范

    1. 组件 日志组件有很多,日志门面的选择 Slf4j Apache Commons Logging 日志的实现有...

  • Slf4j的bind和bridge过程

    Slf4j作为门面,屏蔽底层日志的实现。实现对各种日志的对接。 bind Slf4j没有提供真实的实现,跟踪代码会...

网友评论

      本文标题:日志门面SLF4J

      本文链接:https://www.haomeiwen.com/subject/zwwtirtx.html