Java日志体系梳理分析示例

网友投稿 339 2022-08-18


Java日志体系梳理分析示例

目录一、困扰的疑惑二、how to use三、结束

一、困扰的疑惑

目前的日志框架有 jdk 自带的logging,log4j1、log4j2、logback ,这些框架都自己定制了日志 API ,并且有相应的实现;

目前用于实现日志统一的框架 Apache commons-logging(jcl)、slf4j ,遵循「面向接口编程」的原则,这两大框架可以让用户在程序运行期间去选择具体的日志实现系统(log4j1\log4j2\logback等)来记录日志,是统一抽象出来的一些接口。

通俗的理解:logging、log4j、logback等都是真正负责记录日志的小弟,而commons-logging和slf4j则是这群小弟的大哥,这些大哥本身是不去记录日志的,只是负责接活,并分配活给某个或某几个小弟去干。

其中需要注意的是:记录日志是一件事,比如说slf4j一般会让某一个小弟去记录日志,比如让logback去记录日志。但是在以前记录日志是log4j做的事,这时候就需要把log4j的工作收回到slf4j的手中,slf4j再转给logback,这时候只需要引入对应的交接包就可以了。

这些日志系统涉及到的繁杂的各种集成 jar 包,如下:

log4j、log4j-api、log4j-corelog4j-1.2-api、log4j-jcl、log4j-slf4j-impl、log4j-jullogback-core、logback-classic、logback-accesscommons-loggingslf4j-api、slf4j-log4j12、slf4j-simple、jcl-over-slf4j、slf4j-jdk14、log4j-over-slf4j、slf4j-jcl

log4j

Apache 的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接口服务 器、NT的事件记录器、UNIX Syslog守护进程等;用户也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,用户能够更加细致地控制日志的生成过程。这些可以通过一个 配置文件来灵活地进行配置,而不需要修改程序代码。最新的目前版本为log4j 1.2,maven 依赖如下:

log4j log4j 1.2.17

Logback

Logback 是由 log4j 创始人设计的又一个开源日记组件,Logback 当前分成三个模块:logback-core,logback- classic和logback-access。logback-core是其它两个模块的基础模块,logback-classic是log4j的一个 改良版本。此外logback-classic 完整实现 SLF4J API 使你可以很方便地更换成其它日记系统如log4j或JDK14 Logging。logback-access访问模块与Servlet容器集成提供通过Http来访问日记的功能。maven 最新依赖如下:

ch.qos.logback logback-core 1.1.6 ch.qos.logback logback-classic 1.1.6 org.slf4j slf4j-api 1.7.18

Logback 作为一个通用可靠、快速灵活的日志框架,将作为 Log4j 的替代和 SLF4J 组成新的日志系统的完整实现。Logback 声称具有极佳的性能,“ 某些关键操作,比如判定是否记录一条日志语句的操作,其性能得到了显著的提高。这个操作在LogBack中需要3纳秒,而在Log4J中则需要30纳秒。 LogBack 创建记录器(logger)的速度也更快:13微秒,而在Log4J中需要2XKGQMXGodp3微秒。更重要的是,它获取已存在的记录器只需94纳秒,而 Log4J需要2234纳秒,时间减少到了1/http://23。跟JUL相比的性能提高也是显著的”。另外,Logback的所有文档是全面免费提供的,不象Log4J那样只提供部分免费文档而需要用户去购买付费文档。具体包括:

更快的执行速度更充分的测试logback-classic 非常自然的实现了SLF4J使用XML配置文件或者Groovy自动重新载入配置文件优雅地从I/O错误中恢复自动清除旧的日志归档文件自动压缩归档日志文件谨慎模式Lilith配置文件中的条件处理更丰富的过滤Logback-access模块,提供了通过HTTP访问日志的能力,是logback不可或缺的组成部分

SLF4J

简单日记门面(Facade) SLF4J 是为各种 loging APIs 提供一个简单统一的接口,从而使得最终用户能够在部署的时候配置自己希望的loging APIs实现。 Logging API实现既可以选择直接实现SLF4J接的loging APIs如: NLOG4J、SimpleLogger。也可以通过SLF4J提供的API实现来开发相应的适配器如Log4jLoggerAdapter、JDK14LoggerAdapter。

Apache Common-Logging

目前广泛使用的java日志门面库。通过动态查找的机制,在程序运行时自动找出真正使用的日志库。但由于它使用了ClassLoader寻找和载入底层的日志库, 导致了象OSGI这样的框架无法正常工作,由于其不同的插件使用自己的ClassLoader。 OSGI的这种机制保证了插件互相独立,然而确使Apache Common-Logging无法工作。

SLF4J 库类似于 Apache Common-Logging。但是,他在编译时静态绑定真正的Log库。使用SLF4J时,如果你需要使用某一种日志实现,那么你必须选择正确的SLF4J的jar包的集合,如此便可以在OSGI中使用了。另外,SLF4J 支持参数化的log字符串,避免了之前为了减少字符串拼接的性能损耗而不得不写的if(logger.isDebugEnable()),现在你可以直接写:logger.debug(“current user is: {}”, user)。拼装消息被推迟到了它能够确定是不是要显示这条消息的时候,但是获取参数的代价并没有幸免。同时,日志中的参数若超过三个,则需要将参数以数组的形式传入,如:

Object[] params = {value1, value2, value3};logger.debug(“first value: {}, second value: {} and third value: {}.”, params);

现在,Hibernate、Jetty、Spring-OSGi、Wicket和MINA等越来越多的开源项目都已经迁移到了SLF4J,由此可见SLF4J的影响力不可忽视。

二、how to use

介绍完这些日志框架后,那么这些东西怎么用,之间的依赖是什么样子的,还有启动初始化的过程究竟干了什么,怎么找到相应的实现类及配置的?

这四篇文章是我目前在互联网上面发现的写的最详细的介绍,请参考:

jdk-logging、log4j、logback日志介绍及原理 三个日志系统的实现机制介绍commons-logging与jdk-logging、log4j1、log4j2、logback的集成原理 Apache Commons-logging 通用日志框架与日志系统的机制介绍SLF4J 与 jdk-logging、log4j1、log4j2、logback的集成原理 SLF4J 通用日志框架与具体日志实现系统的机制机制介绍,包括依赖的jar包,jar冲突处理等;slf4j、jcl、jul、log4j1、log4j2、logback大总结 各个组件的jar包以及目前系统日志需要切换实现方式的方法。

org.slf4jslf4j-api1.7.7ch.qos.logbacklogback-core1.1.3ch.qos.logbacklogback-classic1.1.3org.slf4jslf4j-log4j1299.0-does-not-existorg.slf4jlog4j-over-slf4j1.7.14-SNAPSHOTorg.slf4jjcl-over-slf4j1.7.7log4jlog4j99.0-does-not-existapache-log4jlog4j999-not-exist

三、结束

通过上述阅读,对「混乱的 java 日志体系」应该有了较清楚的理解,但是真的存在项目需要切换日志系统的情况吗?根据我的理解,很多当你的系统越来越庞大,越来越复杂需要系统重构,解决性能的时候,可以考虑升级你当前的日志配置。如果你是新启用的项目,直接考虑使用Logback + SLF4j 即可。

以上就是Java日志体系梳理分析示例的详细内容,更多关于Java日志体系的资料请关注我们其它相关文章!


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:springBoot中的properties配置解析
下一篇:SpringBoot中使用Redis作为全局锁示例过程
相关文章

 发表评论

暂时没有评论,来抢沙发吧~