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

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相关的依赖:

		
			org.apache.kafka
			kafka_2.11
			0.9.0.1
			 
				
					org.slf4j
					slf4j-log4j12
				
				
					log4j
					log4j
				
		    
		
参考:http://www.slf4j.org/codes.html#multiple_bindings


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

		 
			org.apache.logging.log4j
			log4j-1.2-api
			2.5
		
参考:https://logging.apache.org/log4j/2.x/manual/migration.html

问题就解决了。



你可能感兴趣的:(log4j,log4j2,kafka,Java开发,项目配置,疑难杂症,Message,Queue)