日志门面

1、Apache通用日志接口(commons-logging.jar)

Apache Commons包中的一个,包含了日志功能,必须使用的jar包。这个包本身包含了一个Simple Logger,但是功能很弱。在运行的时候它会先在CLASSPATH找log4j,如果有,就使用log4j,如果没有,就找JDK1.4带的 java.util.logging,如果也找不到就用Simple Logger。commons-logging.jar的出现是一个历史的的遗留的遗憾,当初Apache极力游说Sun把log4j加入JDK1.4,然而JDK1.4项目小组已经接近发布JDK1.4产品的时间了,因此拒绝了Apache的要求,使用自己的java.util.logging,这个包的功能比log4j差的很远,性能也一般。后来Apache就开发出来了commons-logging.jar用来兼容两个logger。因此用 commons-logging.jar写的log程序,底层的Logger是可以切换的,你可以选择log4j,java.util.logging或者它自带的Simple Logger。
不过我仍然强烈建议使用log4j,因为log4j性能很高,log输出信息时间几乎等于System.out,而处理一条log平均只需要5us。

2、slf4j
slf4j(全称是Simple Loging Facade For Java)是一个为Java程序提供日志输出的统一接口,并不是一个具体的日志实现方案,就好像我们经常使用的JDBC一样,只是一种规则而已。因此单独的slf4j是不能工作的,它必须搭配其他具体的日志实现方案,比如apache的org.apache.log4j.Logger,jdk自带的java.util.logging.Logger等等。
commons-logging和slf4j一样都是日志的接口, log4j,logback等等才是日志的真正实现。当我们调用接口时,接口的工厂会自动寻找恰当的实现,返回一个实现的实例给我服务。这些过程都是透明化的,用户不需要进行任何操作!

3 、slf4j2
Apache Log4j2是对Log4j的升级,与其前身Log4j 1.x相比有了显着的改进,并提供了许多Logback等可用的改进

Commons Logging与Slf4j实现机制对比

Commons Logging实现机制
Commons Logging是通过动态查找机制,在程序运行时,使用自己的ClassLoader寻找和载入本地具体的实现。详细策略可以查看commons-logging-*.jar包中的org.apache.commons.logging.impl.LogFactoryImpl.java文件。由于Osgi不同的插件使用独立的ClassLoader,Osgi的这种机制保证了插件互相独立, 其机制限制了Commons Logging在Osgi中的正常使用。

Slf4j实现机制
Slf4j在编译期间,静态绑定本地的Log库,因此可以在Osgi中正常使用。它是通过查找类路径下org.slf4j.impl.StaticLoggerBinder,然后在StaticLoggerBinder中进行绑定。

SLF4J(Simple logging Facade for Java)

意思为简单日志门面,它是把不同的日志系统的实现进行了具体的抽象化,只提供了统一的日志使用接口,使用时只需要按照其提供的接口方法进行调用即可,由于它只是一个接口,并不是一个具体的可以直接单独使用的日志框架,所以最终日志的格式、记录级别、输出方式等都要通过接口绑定的具体的日志系统来实现,这些具体的日志系统就有log4j,logback,java.util.logging等,它们才实现了具体的日志系统的功能。

如何使用SLF4J?

既然SLF4J只是一个接口,那么实际使用时必须要结合具体的日志系统来使用,我们首先来看SLF4J和各个具体的日志系统进行绑定时的框架原理图:

其实slf4j原理很简单,他只提供一个核心slf4j api(就是slf4j-api.jar包),这个包只有日志的接口,并没有实现,所以如果要使用就得再给它提供一个实现了些接口的日志包,比 如:log4j,logback,jdk log日志实现包等,但是这些日志实现又不能通过接口直接调用,实现上他们根本就和slf4j-api不一致,因此slf4j又增加了一层来转换各日志实现包的使 用,当然slf4j-simple除外。其结构如下:

slf4j-api(接口层)
->各日志实现包的连接层( slf4j-jdk14, slf4j-log4j)
-> 各日志实现包

所以,结合各日志实现包使用时提供的jar包情况为:

SLF4J和logback结合使用时需要提供的jar:slf4j-api.jar,logback-classic.jar,logback-core.jar

SLF4J和log4j结合使用时需要提供的jar:slf4j-api.jar,slf4j-log412.jar,log4j.jar

SLF4J和JDK中java.util.logging结合使用时需要提供的jar:slf4j-api.jar,slf4j-jdk14.jar

SLF4J和simple(SLF4J本身提供的一个接口的简单实现)结合使用时需要提供的jar:slf4j-api.jar,slf4j-simple.jar

当然还有其他的日志实现包,以上是经常会使用到的一些。

注意,以上slf4j和各日志实现包结合使用时最好只使用一种结合,不然的话会提示重复绑定日志,并且会导致日志无法输出。

slf4j-api.jar:对外提供统一的日志调用接口,该接口具体提供的调用方式和方法举例说明:

public class Test {private static final Logger logger = LoggerFactory.getLogger(Tester.class);  //通过LoggerFactory获取Logger实例public static void main(String[] args) {//接口里的统一的调用方法,各具体的日志系统都有实现这些方法logger.info("testlog: {}", "test"); logger.debug("testlog: {}", "test");logger.error("testlog: {}", "test");logger.trace("testlog: {}", "test");logger.warn("testlog: {}", "test");}
}

如果系统中之前已经使用了log4j做日志输出,想使用slf4j作为统一的日志输出,该怎么办呢?

如果之前系统中是单独使用log4j做为日志输出的,这时再想使用slf4j做为日志输出时,如果系统中日志比较多,此时更改日志输出方法肯定是不太现实的,这个时候就可以使用log4j-over-slf4j.jar将使用log4j日志框架输出的日志路由到slf4j上来统一采用slf4j来输出日志。

为什么要使用SLF4J?

  • slf4j是一个日志接口,自己没有具体实现日志系统,只提供了一组标准的调用api,这样将调用和具体的日志实现分离,使用slf4j后有利于根据自己实际的需求更换具体的日志系统,比如,之前使用的具体的日志系统为log4j,想更换为logback时,只需要删除log4j相关的jar,然后加入logback相关的jar和日志配置文件即可,而不需要改动具体的日志输出方法,试想如果没有采用这种方式,当你的系统中日志输出有成千上万条时,你要更换日志系统将是多么庞大的一项工程。如果你开发的是一个面向公众使用的组件或公共服务模块,那么一定要使用slf4的这种形式,这有利于别人在调用你的模块时保持和他系统中使用统一的日志输出。

  • slf4j日志输出时可以使用{}占位符,如,logger.info(“testlog: {}”,
    “test”),而如果只使用log4j做日志输出时,只能以logger.info(“testlog:”+“test”)这种形式,前者要比后者在性能上更好,后者采用+连接字符串时就是new
    一个String 字符串,在性能上就不如前者。

日志框架

  1. Log4j Apache Log4j是一个基于Java的日志记录工具。它是由Ceki
    Gülcü首创的,现在则是Apache软件基金会的一个项目。 Log4j是几种Java日志框架之一。
  2. Log4j 2 Apache Log4j 2是apache开发的一款Log4j的升级产品。
  3. Logback 一套日志组件的实现(slf4j阵营)。
  4. Jul (Java Util Logging),自Java1.4以来的官方日志实现。

log4j(log for java)

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

如何使用?

  • 引入jar,使用log4j时需要的jar为:log4j.jar。
  • 定义配置文件log4j.properties或log4j.xml
  • 在具体的类中进行使用:

1.在需要日志输出的类中加入:private static final Logger logger = Logger.getLogger(Tester.class); //通过Logger获取Logger实例

2.在需要输出日志的地方调用相应方法即可:logger.debug(“System …..”)

logback

logback同样是由log4j的作者设计完成的,拥有更好的特性,用来取代log4j的一个日志框架,是slf4j的原生实现(即直接实现了slf4j的接口,而log4j并没有直接实现,所以就需要一个适配器slf4j-log4j12.jar),logback一共有以下几个模块:

  • logback-core:其它两个模块的基础模块
  • logback-classic:它是log4j的一个改良版本,同时它完整实现了slf4j API使你可以很方便地更换成其它日志系统如log4j或JDK14 Logging
  • logback-access:访问模块与Servlet容器集成提供通过Http来访问日志的功能

同样,单独使用它时,需要引入以上jar,然后进行配置文件的配置,最后就是在相关类中进行使用,使用时加入以下语句:

private final static Logger logger = LoggerFactory.getLogger(Test.class);
logger.info("打印日志");

一些写的很详细的参考

关于如何单独使用log4j,建议详细阅读以下文章:
https://blog.csdn.net/u012422446/article/details/51199724
https://blog.csdn.net/azheng270/article/details/2173430/
http://shmilyaw-hotmail-com.iteye.com/blog/2410764

对于logback的使用,详细使用方法及配置推荐阅读以下文章:
https://www.cnblogs.com/warking/p/5710303.html

送上slf4j和log4j整合使用时的一些参考链接
https://blog.csdn.net/javaloveiphone/article/details/52486257 (log桥接工具jcl-over-slf4j使用,项目排除commons-logging依赖的影响)
https://blog.csdn.net/minicto/article/details/52672472
https://blog.csdn.net/foreverling/article/details/51385128
https://www.cnblogs.com/junzi2099/p/7930268.html#_label6

关于java日志框架整体详细介绍和源码解析
https://www.cnblogs.com/chenhongliang/p/5312517.html#%E6%BA%90%E7%A0%81%E8%BF%BD%E8%B8%AA%E5%88%86%E6%9E%90
https://blog.csdn.net/qq_35642036/article/details/112062859
https://www.cnblogs.com/chenhongliang/p/5312517.html (java常用日志框架介绍)

Java各类日志门面(slf4j,commons-logging)和日志框架(log4j,logback)联系和区别相关推荐

  1. slf4j导入那个依赖_学习SPRINGBOOT结合日志门面SLF4J和日志实现LOGBACK的混合使用

    一.此处主要介绍在springboot工程下如何使用 logback + slf4j 进行日志记录. logback主要包含三个组成部分:Loggers(日志记录器).Appenders(输出目的在) ...

  2. java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory解决方案

    java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory解决方案 参考文章: (1)java.lang.NoClass ...

  3. Caused by: java.lang.ClassNotFoundException: org.apache.commons.logging.LogFactory

    1.错误叙述性说明 2014-7-12 0:38:57 org.apache.catalina.core.ApplicationContext log 信息: No Spring WebApplica ...

  4. java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory 解决方案

    java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory 解决方案 NoClassDefFoundErrorLogFa ...

  5. VSCrawler 爬虫 java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory 解决方案

    长长的报错信息如下: 13:39:15.345 [main] WARN c.v.vscrawler.core.event.EventLoop - 程序已停止 13:39:15.376 [main] I ...

  6. spring boot使用logback时控制台不打印日志,使用slf4j解决不打印日志问题

    maven项目在pom中添加slf4j依赖 <!--用于解决日志不打印问题--> <dependency><groupId>org.slf4j</groupI ...

  7. 运行错误:Exception in thread “main“ java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactor

    这是我们在做OSS文件上传时容易发生的错误,提示说没有日志相关的类,是因为没有导入相关的jar包,所以我们只需要导入一个commons-logging就好了 <!-- https://mvnre ...

  8. struts2与struts1整合,java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory

    原因:我往项目的WEB-INF/lib中导入了struts2基本的包,还有struts1的core包,以及struts2-strut1-plugin的包,但是没有导入commons-loggin-1. ...

  9. java常用日志框架日志门面及实现 SLF4J 、Jboss-logging 、JCL、Log4j、Logback、Log4j2、JUL,springboot集成 log4j、log4j2

    java常用日志框架日志门面SLF4J .Jboss-logging .JCL.Log4j及实现 Logback.Log4j2.JUL,springboot集成 log4j.log4j2 .logba ...

最新文章

  1. linux远程安装本机软件,我的电脑怎样让对方远程装软件?
  2. python 获取ip
  3. 函数伪代码_Excel常用函数
  4. mysql命令导出数据库_MYSQL 数据库导入导出命令
  5. php include无效,php 两次include后,第一个include里的变量无效了
  6. scrolling=no 无法根据坐标获取元素_提高三坐标测量精度,要记住这几招
  7. 提升Windows 7在双核CPU下的启动速度
  8. C#两路list数组归并去重
  9. class CText{}; CText t; int const CText::*p; 什么意思?
  10. 微信商户平台所有产品总结
  11. 淘宝店铺链接获取seller id,拿到店铺所有商品接口,接口接入技术解决方案
  12. lombok slfj 中_Lombok快速入门
  13. C++ 移动语义学习
  14. 对耳朵伤害最小的耳机有哪些,不伤耳的蓝牙耳机推荐
  15. 半加器、全加器的FPGA实现
  16. 如何在头条做好影视解说自媒体?
  17. 3-动态规划:数字三角形
  18. 九张图读懂大数据医疗
  19. 《数学之美》第二十一章——拼音输入法的数学原理
  20. 简单使用 uwsgi + nginx 在本地 Ubuntu 成功部署 django 项目

热门文章

  1. ClownFish是什么?
  2. 虚拟机ubuntu中ens33没有ip
  3. 计算机网络基本知识教学设计,计算机网络基础知识教学设计.doc
  4. yylabel 加载html,YYKit是个好东西-YYLabel实现一个文本多个点击事件
  5. 【FPGA】Verilog:MSI/LSI 组合电路之解码器 | 多路分解器
  6. JAVA基础面试题目
  7. S5PV210学习笔记——(2) 启动阶段的设置
  8. EditText上关闭软键盘但保留闪烁游标的方法
  9. 在新东家工作了1328天,明天回老东家
  10. Speedoffice(excel)设置按颜色进行排序