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
问题就解决了。