这是我参与11月更文挑战的第4天,活动详情查看:2021最后一次更文挑战
常用日志框架
基础日志框架
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公共库:mvnrepository.com/ log4j.properties:blog.csdn.net/sinat_30185… log4j2与Servlet版本:www.cnblogs.com/bigbang92/p… log4j2.xml:www.cnblogs.com/hafiz/p/617… logback.xml:www.cnblogs.com/warking/p/5… springboot日志使用:blog.csdn.net/u010598111/…
------The End------
如果对您有用,或者您希望持续关注,可以在微信公众号中搜索【码路无涯】
感谢大家看到最后,文章持续更新!欢迎大家指出我的文章的不足之处,也欢迎大家关注、收藏+分享