java日志组件介绍(common-logging,log4j,slf4j,logback)

james_karon james_karon     2022-12-01     504

关键词:


logback--官网:

​http://logback.qos.ch/manual/configuration.html​

 

common-logging

common-logging是apache提供的一个通用的日志接口。用户可以自由选择第三方的日志组件作为具体实现,像log4j,或者jdk自带的logging, common-logging会通过动态查找的机制,在程序运行时自动找出真正使用的日志库。当然,common-logging内部有一个Simple logger的简单实现,但是功能很弱。所以使用common-logging,通常都是配合着log4j来使用。使用它的好处就是,代码依赖是common-logging而非log4j, 避免了和具体的日志方案直接耦合,在有必要时,可以更改日志实现的第三方库。

 

使用common-logging的常见代码:

[java] 
​​view plain​​​
​​​copy​​




1. import org.apache.commons.logging.Log;
2. import org.apache.commons.logging.LogFactory;
3.
4. public class A
5. private static Log logger = LogFactory.getLog(this.getClass());
6.


动态查找原理:Log 是一个接口声明。LogFactory 的内部会去装载具体的日志系统,并获得实现该Log 接口的实现类。LogFactory 内部装载日志系统的流程如下:



  1. 首先,寻找org.apache.commons.logging.LogFactory 属性配置。
  2. 否则,利用JDK1.3 开始提供的service 发现机制,会扫描classpah 下的META-INF/services/org.apache.commons.logging.LogFactory文件,若找到则装载里面的配置,使用里面的配置。
  3. 否则,从Classpath 里寻找commons-logging.properties ,找到则根据里面的配置加载。
  4. 否则,使用默认的配置:如果能找到Log4j 则默认使用log4j 实现,如果没有则使用JDK14Logger 实现,再没有则使用commons-logging 内部提供的SimpleLog 实现。

从上述加载流程来看,只要引入了log4j 并在classpath 配置了log4j.xml ,则commons-logging 就会使log4j 使用正常,而代码里不需要依赖任何log4j 的代码。


 

slf4j

slf4j全称为Simple Logging Facade for JAVA,java简单日志门面。类似于Apache Common-Logging,是对不同日志框架提供的一个门面封装,可以在部署的时候不修改任何配置即可接入一种日志实现方案。但是,他在编译时静态绑定真正的Log库。使用SLF4J时,如果你需要使用某一种日志实现,那么你必须选择正确的SLF4J的jar包的集合(各种桥接包)。

使用slf4j的常见代码:



[java] 
​​view plain​​​
​​​copy​​




1. import org.slf4j.Logger;
2. import org.slf4j.LoggerFactory;
3.
4. public class A
5. private static Log logger = LogFactory.getLog(this.getClass());
6.

slf4j静态绑定原理:SLF4J 会在编译时会绑定import org.slf4j.impl.StaticLoggerBinder; 该类里面实现对具体日志方案的绑定接入。任何一种基于slf4j 的实现都要有一个这个类。如:org.slf4j.slf4j-log4j12-1.5.6: 提供对 log4j 的一种适配实现。注意:如果有任意两个实现slf4j 的包同时出现,那么就可能出现问题。

 



slf4j 与 common-logging 比较


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



slf4j在编译时静态绑定真正的Log库,因此可以再OSGI中使用。另外,SLF4J 支持参数化的log字符串,避免了之前为了减少字符串拼接的性能损耗而不得不写的if(logger.isDebugEnable()),现在你可以直接写:logger.debug(“current user is: ”, user)。拼装消息被推迟到了它能够确定是不是要显示这条消息的时候,但是获取参数的代价并没有幸免。



Log4j


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


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来访问日记的功能。 


Log4j 与 LogBack 比较


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


 



slf4j与其他各种日志组件的桥接



应用代码中使用slf4j接口,接入具体实现的方法



(转)



应用代码中使用别的日志接口,转成slf4j的方法



(转)





日志组件相关历史


Java 界里有许多实现日志功能的工具,最早得到广泛使用的是 log4j,许多应用程序的日志部分都交给了 log4j,不过作为组件开发者,他们希望自己的组件不要紧紧依赖某一个工具,毕竟在同一个时候还有很多其他很多日志工具,假如一个应用程序用到了两个组件,恰好两个组件使用不同的日志工具,那么应用程序就会有两份日志输出了。


为了解决这个问题,Apache Commons Logging (之前叫 Jakarta Commons Logging,JCL)粉墨登场,JCL 只提供 log 接口,具体的实现则在运行时动态寻找。这样一来组件开发者只需要针对 JCL 接口开发,而调用组件的应用程序则可以在运行时搭配自己喜好的日志实践工具。


所以即使到现在你仍会看到很多程序应用 JCL + log4j 这种搭配,不过当程序规模越来越庞大时,JCL的动态绑定并不是总能成功,具体原因大家可以 Google 一下,这里就不再赘述了。解决方法之一就是在程序部署时静态绑定指定的日志工具,这就是 SLF4J 产生的原因。


跟 JCL 一样,SLF4J 也是只提供 log 接口,具体的实现是在打包应用程序时所放入的绑定器(名字为 slf4j-XXX-version.jar)来决定,XXX 可以是 log4j12, jdk14, jcl, nop 等,他们实现了跟具体日志工具(比如 log4j)的绑定及代理工作。举个例子:如果一个程序希望用 log4j 日志工具,那么程序只需针对 slf4j-api 接口编程,然后在打包时再放入 slf4j-log4j12-version.jar 和 log4j.jar 就可以了。


现在还有一个问题,假如你正在开发应用程序所调用的组件当中已经使用了 JCL 的,还有一些组建可能直接调用了 java.util.logging,这时你需要一个桥接器(名字为 XXX-over-slf4j.jar)把他们的日志输出重定向到 SLF4J,所谓的桥接器就是一个假的日志实现工具,比如当你把 jcl-over-slf4j.jar 放到 CLASS_PATH 时,即使某个组件原本是通过 JCL 输出日志的,现在却会被 jcl-over-slf4j “骗到”SLF4J 里,然后 SLF4J 又会根据绑定器把日志交给具体的日志实现工具。过程如下


Component

|

| log to Apache Commons Logging

V

jcl-over-slf4j.jar --- (redirect) ---> SLF4j ---> slf4j-log4j12-version.jar ---> log4j.jar ---> 输出日志


看到上面的流程图可能会发现一个有趣的问题,假如在 CLASS_PATH 里同时放置 log4j-over-slf4j.jar 和 slf4j-log4j12-version.jar 会发生什么情况呢?没错,日志会被踢来踢去,最终进入死循环。


所以使用 SLF4J 的比较典型搭配就是把 slf4j-api、JCL 桥接器、java.util.logging(JUL)桥接器、log4j 绑定器、log4j 这5个 jar 放置在 CLASS_PATH 里。


不过并不是所有APP容器都是使用 log4j 的,比如 Google AppEngine 它使用的是 java.util.logging(JUL),这时应用 SLF4J 的搭配就变成 slf4j-api、JCL桥接器、logj4桥接器、JUL绑定器这4个 jar 放置在 WEB-INF/lib 里。

spring替换掉默认的common-logging.jar

...用它打印大批量数据会占用大量的资源 spring默认使用common-logging打印日志信息如果我们想替换掉它使用其他的日志工具分为如下几步1.排除项目对common-logging的依赖<dependency><groupId>org.springfr 查看详情

实现jul日志重定向到slf4j

...是java内置的日志模块,目前流行的Java日志组件还包括jcl(common-logging)、slf4j/log4j/logback等等 不同日志框架的定位和特性都存在差异,如jcl、slf4j提供的是日志门面(api)定义,log4j、logback则侧重于实现。通常一个团队会采用统一... 查看详情

common-logging这个jar包是干什么用的

common-logging这个jar包是干啥用的编写一个库的时候记录信息是很有用的,但是有许多日志,一个库不能将一个特殊的应用强加于整个应用。日志包是一个不同日志实现之间很薄的桥梁。一个使用这个commons-loggingAPI的库可以在运行... 查看详情

日志组件log2net的介绍和使用(附开源地址)

  Log2Net是一个用于收集日志到数据库或文件的组件,支持.NET和.NetCore平台。此组件自动收集系统的运行日志(服务器运行情况、在线人数等)、异常日志。程序员还可以添加自定义日志。该组件支持.NET平台和.NETCore平台,支... 查看详情

日志组件logback的介绍及配置使用方法

...    Logback是由log4j创始人设计的又一个开源日志组件。logback当前分成三个模块:logback-core,logback-classic和logback-access。logback-core是其它两个模块的基础模块。logback-classic是log4j的一个改良版本。此外logback-classic完整实 查看详情

java日志框架介绍

 Log4jApacheLog4j是一个基于Java的日志记录工具。它是由CekiGülcü首创的,现在则是Apache软件基金会的一个项目。Log4j是几种Java日志框架之一。 Log4j2ApacheLog4j2是apache开发的一款Log4j的升级产品。 CommonsLoggingApache基金会所属的项... 查看详情

log4j的多logger记录日志的简明使用(代码片段)

日志,应该是一个应用软件的基础功能之一。使用java语言,必然会使用一个日志库,我使用的是log4j的日志库。网上不少文章都有介绍,但是结合logger的不同功能介绍以及示例介绍的清楚的不多,至少我也是翻了不少网页,然后... 查看详情

netcore体系-web应用程序7asp.netcore日志组件

日志介绍Logging的使用1.appsettings.json中Logging的介绍Logging的配置信息是保存在appsettings.json配置文件中的。因为之前介绍配置文件的时候我们使用的是appsettings.Development.json这个文件,所以在介绍Logging的时候我们也用它吧。通过上图... 查看详情

bizlog通用操作日志组件(代码分析篇)(代码片段)

引言在上篇博客中介绍了通用操作日志组件的使用方法,本篇博客将从源码出发,学习一下该组件是如何实现的。代码结构该组件主要是通过AOP拦截器实现的,整体上可分为四个模块:AOP模块、日志解析模块、日... 查看详情

java日志组件

...log4j发生了很大变化,不兼容。log4j仅仅作为一个实际的日志框架,slf4j、commons-logging作为门面统一各种日志框架的混乱格局,现在log4j2也想跳出来当门面,也想统一大家。日志越来越乱了log4j-api:作为日志接口层,用于统一底层... 查看详情

关于log4jjuljclslf4j等等日志组件的理解

日志组件:  我们经常在开发项目的时候,需要打印记录项目过程中的一些日志。那我们经常大概会用到log4j、jul、jcl、slf4j、simple、nop、logback等等,那我们就详细介绍下这些组件是怎么做日志打印的JUL:JUL全称JavautilLogging是j... 查看详情

想要将我们的osgi框架中的批量日志单独打印到文件中

...依赖logback,但遗憾的是也没有使用slf4j,而是使用了ApacheCommon-Loggingslf4j和common-logging有什么区别呢 common-logging通过动态查找的机制,在程序运行时自动找出真正使用的日志库。由于它使用了ClassLoader寻找和载入底层的日志库... 查看详情

java日志框架--日志框架介绍jul日志学习

1.日志的概念日志文件是用于记录系统操作事件的文件集合,可分为事件日志和消息日志。具有处理历史数据、诊断问题的追踪以及理解系统的活动等重要作用。2.Java日志框架问题:控制日志输出的内容和格式。控制日志... 查看详情

springboot初始教程之日志处理

SpringBoot初始教程之日志处理(二)1.介绍SpringBoot默认是采用logback进行日志处理、Logback是由log4j创始人设计的又一个开源日志组件。Logback是由log4j创始人设计的又一个开源日志组件。logback当前分成三个模块:logback-core,logback-classic和... 查看详情

java日志介绍-java.util.logging.logger

java.util.logging.Logger是JDK自带的日志工具,其简单实现了日志的功能,不是很完善,所以在实际应用中使用的比较少。本文直接用代码演示其使用方法,文中所使用到的软件版本:Java1.8.0_191。packagecom.inspur.demo.log;importjava.util.logging... 查看详情

java使用双内存缓冲区实现简易日志组件(代码片段)

在实现简易日志组件时,为了写日志的同时,可将日志数据进行写入磁盘实现持久化。如果每记录一条日志就写一次磁盘文件的话,磁盘IO会占用正常处理逻辑的性能。因此,采用双内存缓冲区的思路来将写日志... 查看详情

java日志框架学习--jul和log4j--上(代码片段)

Java日志框架学习--JUL和Log4j--上引言日志框架市面流行的日志框架日志门面和日志框架的区别JULJUL简介JUL组件介绍实际使用Logger之间的父子关系默认配置文件位置读取自定义配置文件追加日志信息Log4jLog4j简介Log4j组件介绍LoggersAppe... 查看详情

java日志框架--jcl日志门面(jcl概念介绍jcl示例)(代码片段)

1.JCL全称为JakartaCommonsLogging,是Apache提供的一个通用日志API。是日志门面的一种实现方式,另外一种日志门面的实现方式是Slf4j。它是为"所有的Java日志实现"提供一个统一的接口,它自身也提供一个日志的实现&#x... 查看详情