白话从commons-logging到slf4j

为了让系统的log实现变成可配置,java的大牛们实现了两种底层接口规范,1.commons-logging 2.slf4j

一、commons-logging这是一个Apache项目,历史悠久,基于classloader的。包括spring都在使用这个log底层接口规范

实现原理:我定义1个LogFactory,这个LogFactory可以生产Log

至于使用哪个LogFactory就要根据系统不同的配置参数,所以他就能够生产出不同厂家的Log

比如说:

commongs-logging在创建LogFactory的时候有这么个顺序,

a.首先去判断jvm配置参数中是否有设置

b.然后在去检测 META-INF/services/org.apache.commons.logging.LogFactory文件

c.实在找不到就去找用户 commons-logging.properties 里面的配置

d.最后是在都没找到的话,那就使用自己的默认实现LogFactoryImpl(LogFactoryImpl这个默认实现比较有意思,他默认可以生产Log4JLogger、Jdk14Logger、Jdk13LumberjackLogger、SimpleLog)

结论:如果使用commons-logging,必须需要配置一个真正的实现log*.jar干活

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

1.slf4j基本包 slf4J-api.jar

2.slf4j桥接具体log实现的包:

    log4j:slf4j-log4j12.jar

    logback:logback-core、logback- classic

3.也可以把slf4j作为commongs-logging的一种实现,需要引入jcl-over-slf4j.jar(这个里面主要关注是在META-INF/services/org.apache.commons.logging.LogFactory文件中配置了LogFactory实现类:org.apache.commons.logging.impl.SLF4JLogFactory)

三、总结

1.目前市面上真正在用的也就是log4j和logback。都是一个人写的,据说logback比log4j性能要好很多,下面看看具体说法

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

2.看看SLF4j和具体实现的关系:

5a8098d4d7d53dc63256010eab7fc6ca325.jpg

 

3. 用别的日志接口,转成slf4j的方法

15ecd50ef611e4d01372c83833c399e9722.jpg

 

1、commons-loggin,slf4j只是一种日志抽象门面,不是具体的日志框架。

2、log4j,logback是具体的日志框架。

3、一般首选使用slf4j+logback,或者slf4j+log4j,commons-logging+log4j。

转载于:https://my.oschina.net/u/1458864/blog/3093078

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果您想要使用Commons Logging与Log4J 2进行日志记录,可以按照以下步骤进行配置: 1. 首先,您需要添加以下依赖项到您的项目中: ``` <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-api</artifactId> <version>2.x.x</version> </dependency> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-core</artifactId> <version>2.x.x</version> </dependency> <dependency> <groupId>commons-logging</groupId> <artifactId>commons-logging</artifactId> <version>1.2</version> </dependency> ``` 其中,`log4j-api`和`log4j-core`是Log4J 2的核心依赖项,而`commons-logging`则是Commons Logging的依赖项。 2. 在项目的classpath下添加一个`log4j2.xml`配置文件,例如: ``` <?xml version="1.0" encoding="UTF-8"?> <Configuration status="WARN"> <Appenders> <Console name="Console" target="SYSTEM_OUT"> <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/> </Console> </Appenders> <Loggers> <Root level="info"> <AppenderRef ref="Console"/> </Root> </Loggers> </Configuration> ``` 这个示例配置文件将日志记录到控制台,并将日志级别设置为`info`。 3. 在代码中使用Commons Logging进行日志记录,例如: ``` import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; public class MyClass { private static final Log LOG = LogFactory.getLog(MyClass.class); public void doSomething() { LOG.info("Doing something..."); } } ``` 在这个示例中,`MyClass`使用Commons Logging来获取日志记录器实例,并在`doSomething()`方法中记录一条日志。 运行应用程序时,您应该可以在控制台上看到与配置文件中定义的日志级别匹配的日志消息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值