日志框架知识 commons-logging log4j slf4j logback java.util.logging

我们经常用到的日志组件有哪些?
commons-logging log4j slf4j logback java.util.logging(JDK自带)

各个组件介绍

commons-logging 是apache最早提供的日志的门面接口,记住这是定义的接口,使用者可以使用不同的 日志实现,面向接口编程,如果需要更换具体的实现,成本很低。
log4j 这是具体的日志实现,最经典的日志组件,不过目前使用的越来越少。
slf4j 这也是日志的门面接口,是目前比较流行的日志门面组件。
logback 具体日志的实现,目前使用比较广泛,是log4j的作者又一顶力之作,性能较log4j有较大提升。
java.util.logging JDK自带的日志实现,用的人比较少,就不多做概述。

各组件之间如何使用

①.commons-logging和slf4j是java中的日志门面,即它们提供了一套通用的接口,具体的实现可以由开发者自由选择。log4j和logback则是具体的日志实现方案。
②.通常情况commons-logging和log4j 配套使用,因为它们是最早出现的日志组件;slf4j和logback配套使用。
③.那么commons-logging和logback可以配套使用吗?slf4j和log4j可以配套使用吗?
答案是不可以,因为他们是两套不同日志组件,slf4j和logback和log4j相比无论在设计、性能上都有很大升级。logback并不是log4j的升级版,而是作者觉得log4j写的太烂,不想在原来基础上升级了。所以他们各自之间想配套使用必须需要一个适配器,也就是下面讲到的桥接器。

桥接器

jcl-over-slf4j.jar : jcl 代表 java commons logging(commons-logging的简称),如果代码中是基于commons-logging来打印日志的,想切换成slf4j+logback, 这个jar包必不可少,而且之前的代码不需要变动。例如:sping中打印日志就是基于commons-logging+log4j打印日志的,你的系统用的logback,那么引入这个jar包就可以。

slf4j-jcl.jar : 和上面相反,当系统使用slf4j+logback进行编码时,如果想切换成commons-logging,引用此jar包,并排除掉logback-classic.jar包,否则会找到两个绑定。

log4j-over-slf4j.jar :如果你的日志打印是基于log4j来进行编程的,那么就引入这个jar, 意思是将log4j桥接到slf4j.
不过要注意要把之前log4j的包给排除掉。

slf4j-log4j12.jar : 和上面相反,如果是使用slf4j打印日志的,如果想切换到log4j则引用此jar包,需要将slf4j-api
给排除掉

常用的桥接包就上面几种。
————————————————
版权声明:本文为CSDN博主「dezun」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/gudejundd/article/details/84105229

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
如果您想要使用Commons LoggingLog4J 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()`方法中记录一条日志。 运行应用程序时,您应该可以在控制台上看到与配置文件中定义的日志级别匹配的日志消息。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值