spring boot log4j2与三方依赖库log4j冲突无法初始化问题解决方法

因为从Spring Boot 1.4开始,spring boot就不支持log4j了,必须是log4j2或者logback,具体两者如何配置以及NDC的支持可以参考spring boot精华版

这里要讲的是如果刚好用的spring boot是1.4+或者应用使用了log4j2,但是依赖的三方使用的是log4j,该如何处理?默认情况下,如果log4j和log4j2实现都存在,spring boot启动时会提示无法初始化log4j,类似如下:

log4j:WARN No appenders could be found for logger (org.I0Itec.zkclient.ZkConnection).
log4j:WARN Please initialize the log4j system properly.

然后日志一条都不打印。。。。
其中方法之一如果三方库依赖的是SLF4J,就把log4j12的依赖排除掉,如下:
复制代码
        <dependency>
            <groupId>org.apache.kafka</groupId>
            <artifactId>kafka_2.12</artifactId>
            <version>0.11.0.3</version>
            <exclusions>
                <exclusion>
                    <groupId>org.slf4j</groupId>
                    <artifactId>slf4j-log4j12</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
复制代码

这样使用log4j2的库日志时可以正常打印了,三方库依赖log4j的就会在运行期间仍然提示上述错误信息。

此时如果强行把三方库依赖的log4j直接排除掉,在启动时会提示“java.lang.NoClassDefFoundError: org/apache/log4j/Logger”,这绝对是不可以接受的。

如果三方库没有提供依赖log4j2的版本,可将依赖的 log4j 后,然后额外加上这个 log4j-1.2-api,如下:

复制代码
        <dependency>
            <groupId>org.apache.kafka</groupId>
            <artifactId>kafka_2.12</artifactId>
            <version>0.11.0.3</version>
            <exclusions>
                <exclusion>
                    <groupId>org.slf4j</groupId>
                    <artifactId>slf4j-log4j12</artifactId>
                </exclusion>
                <exclusion>
                    <groupId>log4j</groupId>
                    <artifactId>log4j</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-1.2-api</artifactId>
        </dependency>
复制代码

 

posted @   zhjh256  阅读(6973)  评论(1编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
历史上的今天:
2016-09-30 centos/rhel 6.5(更新至centos 7)下rabbitmq安装(最简单方便的方式)
点击右上角即可分享
微信分享提示