java log4j、logback简单排查

slf4j

  •   slf4j只是日志系统的API,只是接口,称之为日志框架,类似于JDBCDriver,具体实现由各个厂家提供,而slf4j日志框架的实现目前有两个,一个是LOG4J,一个是logback.
  •   在代码里我们通常会使用 Logger logger = LoggerFactory.getLogger(this.getClass());  来获取Logger,LoggerFactory是 slf4j-api里的一个单例工厂类,最底层调用StaticLoggerBinder.getSingleton().getLoggerFactory()来获取实现类。而StaticLoggerBinder则在各自的厂商中提供。

  那么到底使用的是哪个StaticLoggerBinder呢

private final static void bind() {
try {
Set staticLoggerBinderPathSet = findPossibleStaticLoggerBinderPathSet();

reportMultipleBindingAmbiguity(staticLoggerBinderPathSet);

// the next line does the binding

StaticLoggerBinder.getSingleton();

INITIALIZATION_STATE = SUCCESSFUL_INITIALIZATION;

reportActualBinding(staticLoggerBinderPathSet);

emitSubstituteLoggerWarning();

} catch (NoClassDefFoundError ncde) {
}

....

}

 

项目中引入log4j而不是使用默认的logback_代码

什么是slf4j

SLF4J,即简单日志门面(Simple Logging Facade for Java),不是具体的日志解决方案,它只服务于各种各样的日志系统。按照官方的说法,SLF4J是一个用于日志系统的简单Facade,允许最终用户在部署其应用时使用其所希望的日志System。

为什么使用slf4j

         上面已经介绍了slf4j,那么至于为什么使用它。Slf4j可以看成是接口,那么既然是接口,实现在哪里呢?实现就是基于你自己的系统需要引入什么日志。我这里使用了log4j作为slf4j的实现。那么就可以通过slf4j来输出日志。

slf4j的解耦

         试想一下,如果你使用了第三方的类库,那么比如别人使用了java.util.logging.Logger这个类库系统,那么你的项目使用的是log4j日志系统,你是不是要重新引入2种日志系统呢?那现在就有人为了解决这个问题,就提供了slf4j这个日志接口类库。你只要使用slf4j就可以了,至于你系统使用什么类库作为我的实现,我不管。那么这样问题就解决了,这也符合java的面向对象编程。

 

代码部分,由于sprintboot 默认使用logback,如果想用log4j, 需要排除掉logback的jar,引入log4j 的jar

 

 

 

<dependencies>
        <!--slf4j和log4j日志交换包-->
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
        </dependency>
        <!--log4j包-->
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <!--排除logback包 -->
            <exclusions>
                <exclusion>
                    <groupId>ch.qos.logback</groupId>
                    <artifactId>logback-classic</artifactId>
                </exclusion>
                <exclusion>
                    <groupId>ch.qos.logback</groupId>
                    <artifactId>logback-core</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
    </dependencies>

测试,生效的是log4j:

 

 

 

如果还原依赖:

复制代码
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
    </dependencies>
复制代码

测试结果,看到用的是logback:

反正是就要引入这些包, 但是slf4j-api已经在springboot-web里了。所以我的代码中没有再引入。

//slf4j包
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
    <version>1.8.0-beta2</version>
</dependency>
//slf4j和log4j日志交换包
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-log4j12</artifactId>
    <version>1.8.0-beta2</version>
</dependency>
//log4j包
<dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.17</version><dependency>

最后讲一下用intellij看依赖:

在pom.xml 鼠标右键 

 

 

 

https://blog.csdn.net/weixin_39541044/article/details/114539884

https://www.cnblogs.com/dayanjing/p/13800105.html

posted @ 2021-12-15 09:33  wq9  阅读(781)  评论(0编辑  收藏  举报