使用kafka生产者API时出现此错误:
SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/home/haifa/.ivy2/cache/org.slf4j/slf4j-log4j12/jars/slf4j-log4j12-1.7.29.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/home/haifa/.ivy2/cache/ch.qos.logback/logback-classic/jars/logback-classic-0.9.28.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.
SLF4J: Actual binding is of type [org.slf4j.impl.Log4jLoggerFactory]
在我的build.sbt中,我具有以下依赖性:
<dependency>
<groupId>org.apache.kafka</groupId>
<artifactId>kafka-clients</artifactId>
<version>2.0.0</version>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</exclusion>
</exclusions>
</dependency>
我发现此解决方案使用maven从Kafka依赖项中排除了SFL4J。 但是我在使用sbt时找不到等效的解决方案。
任何人都可以提供帮助。 谢谢。
答案 0 :(得分:0)
登录取决于slf4j-api。您应该排除slf4j-log4j12,它会拉开kafka使用的log4j桥。
您只需在sbt依赖项的末尾添加排除
How to exclude commons-logging from a scala/sbt/slf4j project?