Java系统中,使用log4j2,再引入Kafka依赖后,出现log dependency警告的解决

来源:互联网 发布:虚拟机bt5网络设置 编辑:程序博客网 时间:2024/05/16 15:09

Java系统中,已经使用log4j2,如果再引入Kafka依赖,会出现log dependency警告,大概是说有重复的slf4j库,而且会提示找不到log4j的配置文件。


原因:

1、kafka的java实现使用的是log4j1.2,kafka依赖自动引入了log4j1.2相关的依赖,导致和log4j2依赖重复。

2、kafka的java实现使用的是log4j1.2,所以它要搜索名字为log4j.xml的配置文件,而log4j2的配置文件名为log4j2.xml,所以会提示找不到配置文件。


解决方法:

1、在kafka的依赖中去除掉log相关的依赖:

<dependency><groupId>org.apache.kafka</groupId><artifactId>kafka_2.11</artifactId><version>0.9.0.1</version><exclusions> <!-- exclude掉过时的log依赖 --><exclusion><groupId>org.slf4j</groupId><artifactId>slf4j-log4j12</artifactId></exclusion><exclusion><groupId>log4j</groupId><artifactId>log4j</artifactId></exclusion>    </exclusions></dependency>
参考:http://www.slf4j.org/codes.html#multiple_bindings


2、引入一个log4j2后向兼容的依赖:

<dependency> <!-- 后向兼容:使用Log4j2实现log2j1.x的接口 --><groupId>org.apache.logging.log4j</groupId><artifactId>log4j-1.2-api</artifactId><version>2.5</version></dependency>
参考:https://logging.apache.org/log4j/2.x/manual/migration.html

问题就解决了。



0 0
原创粉丝点击