本文主要讲述slf4j, jcl, logback, log4j2, log4j冲突问题。
适用场景为同时使用thrift, elasticsearch-client, 老内部库等第三方库造成日志管理难度问题。
首先总结java提供的日志系统,它包括:
- jul 全称java-utils-logging, jdk自带的日志系统)
- jcl 全称 apache commons-logging, 是apache commons集合中一个部分
- log4j 全称log for java。
- slf4j 全称 Simple logging facade for Java
- logback 它是log4j改良版
- log4j2 它是log4j的2.x版本
不同的第三方库因为其开始开发的年代不同,使用了不同的日志系统。
从而导致,使用这些第三方库时,需要对他们进行管理,统一管理或者各自管理各自的。
最近开发的一个项目,服务框架使用apache thrift, 使用到了elasticsearch-client和一个内部库。
thrift使用的日志系统是slf4j, elasticsearch-client使用的日志系统是log4j2, 内部库使用的日志系统时jcl,老服务中使用的是logback。
这时维护四份日志的配置文件增加了服务的维护成本,解决的方案是,对日志系统进行桥接,统一维护。
进过查找资料发现:
从slf4j桥接到其它库的组件包括:
从其它库桥接到slf4j库包括:
从其它库桥接到log4j2的库包括:
从当前情况而言,从slf4j,jcl,logback桥接到log4j2的成本较低.
添加log4j-slf4j-impl库和log4j-jcl 库,取出logback库的依赖。
由于logback的配置文件与log4j2的配置文件相近,因此可以平滑迁移。
修改pom文件, 添加下面内容:
<dependency>
<groupId>org.apache.logging.log4jgroupId>
<artifactId>log4j-apiartifactId>
dependency>
<dependency>
<groupId>org.apache.logging.log4jgroupId>
<artifactId>log4j-coreartifactId>
dependency>
<dependency>
<groupId>org.apache.logging.log4jgroupId>
<artifactId>log4j-slf4j-implartifactId>
dependency>
<dependency>
<groupId>org.apache.logging.log4jgroupId>
<artifactId>log4j-jclartifactId>
dependency>
<dependency>
<groupId>org.apache.logging.log4jgroupId>
<artifactId>log4j-julartifactId>
dependency>
<dependency>
<groupId>org.apache.logging.log4jgroupId>
<artifactId>log4j-1.2-apiartifactId>
dependency>
修改elasticsearch-client依赖为:
<dependency>
<groupId>org.elasticsearch.clientgroupId>
<artifactId>transportartifactId>
<exclusion>
<groupId>org.slf4jgroupId>
<artifactId>slf4j-apiartifactId>
exclusion>
<exclusion>
<groupId>ch.qos.logbackgroupId>
<artifactId>logback-classicartifactId>
exclusion>
<exclusion>
<groupId>commons-logginggroupId>
<artifactId>commons-loggingartifactId>
exclusion>
dependency>
修改thrift依赖为:
<dependency>
<groupId>org.apache.thriftgroupId>
<artifactId>libthriftartifactId>
dependency>
<exclusion>
<groupId>org.slf4jgroupId>
<artifactId>slf4j-apiartifactId>
exclusion>
<exclusion>
<groupId>ch.qos.logbackgroupId>
<artifactId>logback-classicartifactId>
exclusion>
<exclusion>
<groupId>commons-logginggroupId>
<artifactId>commons-loggingartifactId>
exclusion>
dependency>
logback->log4j2迁移
slf4j、jcl、jul、log4j1、log4j2、logback大总结
maven search for log4j2