日志门面SLF4J

2022-07-13  本文已影响0人  Tinyspot

SLF4J

image.png

slf4j-core: 日志门面

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

2. 三类

2.1 simple

<!-- 加上 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

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

2.3 SLF4J bind Log4j

<!-- 加上 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

<!-- 加上 slf4j-api 依赖-->
<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <version>1.2.3</version>
</dependency>

2.5 SLF4J bind Log4j 2

<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

上一篇 下一篇

猜你喜欢

热点阅读