应用因缺少Log4j依赖而无法启动怎么解决

应用因缺少Log4j依赖而无法启动怎么解决

应用因缺少Log4j依赖而无法启动怎么解决?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

异常版本的依赖是如下:

<dependency>
 <groupId>com.github.sgroschupf</groupId>
 <artifactId>zkclient</artifactId>
 <version>0.1</version>
</dependency>

正常的依赖是:

<dependency>
 <groupId>com.101tec</groupId>
 <artifactId>zkclient</artifactId>
 <version>0.10</version>
</dependency>

分析到这里,已经有了解决思路,一种是直接修改zkclient的依赖,一种是继续分析为什么两种版本的不同会导致应用启动失败。通过继续分析,发现groupId为com.101tec的日志框架使用的是Slf4j,而groupId为com.github.sgroschupf的日志框架是Log4j,而那位同事在排除aaa依赖的时候顺便把log4j的依赖也排掉了,所以才导致应用启动失败。

com.github.sgroschupf的log框架:

应用因缺少Log4j依赖而无法启动怎么解决

com.101tec的log框架:

应用因缺少Log4j依赖而无法启动怎么解决

再回到刚开始dubbo注册服务失败的问题,一切都明了了——因为把log4j依赖排掉了,导致dubbo使用zkclient注册服务的时候因为无法初始化Log4j,导致无法初始化ZkClient,进而导致dubbo注册失败。

通过这个事件,获得如下教训:

  1. 尽量在一个系统内使用同一个日志框架
  2. 如果是依赖jar有不同的日志实现,使用更高版本的依赖
  3. 发布之前一定要记得在测试环境进行测试

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注行业资讯频道,感谢您对亿速云的支持。