常用日志框架及源码解析
常用日志框架及源码解析
常用日志框架
基础日志框架
log4j、log4j2、logback、JUL(java日志框架)
日志框架集成
JCL、SLF4J
基础日志框架
log4j
<!-- 引入log4j 对应log4j.properties -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
log4j2
<!-- 引入log4j2 对应log4j2.xml -->
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>2.8.2</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.8.2</version>
</dependency>
logback
<!-- 引入logback 对应logback.xml -->
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.2.3</version>
</dependency>
JUL(java日志框架)
日志框架集成
JCL(有自己默认的日志,总会打印出日志)
<!-- jcl -->
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<version>1.2</version>
</dependency>
源码分析
调用静态方法时加载LogFactory类,执行静态块
调用getLog方法:
获取LogFactory对象:
getInstance:
SLF4J(日志接口,无默认日志,必须搭配日志桥接器)
- slf4j只是一个日志标准,并不是日志系统的具体实现。理解这句话非常重要,slf4j只做两件事情:
- 提供日志接口
- 提供获取具体日志对象的方法
- slf4j有自己的简单日志实现,但更重要的是作为一个门面,搭配其他日志实现
slf4j-api的1.7.X版本与1.8.X版本获取ILoggerFactory的方式不同,桥接器实现也不同
个人意见:目前推荐1.7.X,较为成熟
<!-- 只有slf4j-api依赖 -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.13</version>
</dependency>
源码分析
1、怎么找到所有的org/slf4j/impl/StaticLoggerBinder.class
2、由于存在多个org.slf4j.impl.StaticLogerBinder,这时会调用哪一个类的代码呢?
多个桥接器不会导致启动报错,
在这种情况下编译期间,编译器会选择其中一个StaticLoggerBinder.class进行绑定
编译期会调用在classpath中较早出现的org.slf4j.impl.StaticLogerBinder的代码.如在maven中,会调用在pom.xml中定义较靠前的桥接器的代码.
SLF4J日志桥接器
- logback是slf4j的native实现,不需要桥接包 只需要引入logback的jar包即可
- slf4j和log4j桥接包
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.25</version>
</dependency>
- slf4j和log4j2桥接包
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-slf4j-impl</artifactId>
<version>2.8.2</version>
</dependency>
<!--web工程需要包含log4j-web,非web工程不需要-->
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-web</artifactId>
<version>2.8.2</version>
<scope>runtime</scope>
</dependency>
<!--需要使用log4j2的AsyncLogger需要包含disruptor-->
<dependency>
<groupId>com.lmax</groupId>
<artifactId>disruptor</artifactId>
<version>3.2.0</version>
</dependency>
- slf4j和jul桥接包
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-jdk14</artifactId>
<version>1.7.25</version>
</dependency>
- slf4j和jcl桥接包
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-jcl</artifactId>
<version>1.7.25</version>
</dependency>
使用Slf4时如何桥接遗留的api
-
log4j到slf4j的桥梁:log4j-over-slf4j-version.jar
-
jcl到slf4j的桥梁:jcl-over-slf4j-version.jar
-
jul到slf4j的桥梁:jul-to-slf4j-version.jar
-
jcl到log4j2的桥梁:log4j-jcl
例如:
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>log4j-over-slf4j</artifactId>
<version>1.7.25</version>
</dependency>
引用
maven公共库:https://mvnrepository.com/
log4j.properties:https://blog.****.net/sinat_30185177/article/details/73550377
log4j2与Servlet版本:https://www.cnblogs.com/bigbang92/p/log4j2_servlet.html
log4j2.xml:https://www.cnblogs.com/hafiz/p/6170702.html
logback.xml:http://www.cnblogs.com/warking/p/5710303.html
springboot日志使用:https://blog.****.net/u010598111/article/details/80556437