slf4j和log4j、logback
现在主流java项目一般使用slf4j+log4j的日志方案,最近抽点时间扫了一下slf4j、log4j、logback的官方文档,做个笔记。这篇比较不打算描述具体的配置方法,因为官方文档已经讲得很清楚了,而是描述一下核心的概念和方案。大家要对某个日志方案做一个全面了解的话,最好的方式是看官方文档,比baidu强很多。
log4j官方文档[https://logging.apache.org/log4j/2.x/index.html)(https://logging.apache.org/log4j/2.x/index.html)。
logback官方文档https://logback.qos.ch/manual/index.html
slf4j
slf4j是一个日志门面框架,用来解决不同的库使用不同日志方案的问题。slf4j建立了到所有主流日志实现方案的桥接,假设我开发一个组件A,使用slf4j+(slf4j-brigdeto-log4)+log4j的方案来调试。当我发布A的时候,是不带这些日志库的,但是代码里面仍然会有打印日志的语句。当某个用户使用组件A时,他可以使用任意日志方案,只要采用slf4j+(slf4j-brigde-somelog)+somelog这个模式即可。在用户那边,组件A运行毫无障碍,日志功能也很正常,只不过底层的日志输出不再是log4j而是somelog。somelog可以log4j,logback或其它,只要是slf4j支持的日志方案就行。
因此使用这个方案,一般需要引入三个库,依次是:slf4j-api(slf4j接口库,应用代码里面直接使用);slf4j-bridgeto-somelog(slf4到somelog的桥接库);somelog(somelog实现库)。
log4j2
目前使用最多的日志方案,从使用的角度,log4j2有3个核心概念:Logger,Appender,Layout。
1)logger
logger代表一个日志输出对象,它是一个命名对象,并且多个logger通过名字可以形成一个父子层级体系。
假如有一个logger A名字叫做"com",B的名字叫做"com.java",C名字叫做"com.java.controller",那么C是B的后代,B是A的后代。
这样当C通过logger.info输出一条日志时,这条日志会在这个层级中往上传递;当然某个层级的logger可能会某种方式中断这个传递,比如addtivity属性。
log4j必须要配置一个叫做root的logger,它是所有logger的根。
2) Appender
Appender代表日志的输出目的地,每个logger必须要至少绑定一个Appender才能真正输出日志。Appender有很多类型,最常见的就是Console和FileAppender了,分别代表控制台和本地文件。
3) Layout
代表日志的格式化器,是Appender的子元素。在Appender决定要输出一条日志时,才会使用格式化器格式化日志为一条文本。
这意味着,日志的格式化被尽量延迟,所以我们输出日志要使用logger.info("event {} happend at {}",event,location)这样的占位符形式,而不是logger.info("event "+event+" happend at "+location)。前者在日志被过滤的情况下根本不会执行格式化。
4 )Level
level是logger的属性,对日志做一个有序的分类,从低到高依次是TRACE,DEBUG,INFO,WARN,ERROR,FATAL,如果level设置成ERROR,那么只能输出ERROR和FATAL,更低层次的日志会被丢弃。
5 )Filter
fiter是过滤器,可以对日志执行一些过滤操作,他可以用在logger上,也可以用在appender上,还可以用在全局。
最后,如果配置看起来没问题,但是运行却不如预期,怎么办?可以通过System.setProperty("log4j2.debug","true")让log4j打印内部日志(还有其他手段,这里抛砖引玉)。了解上面的这些知识点,再查查资料,复制粘贴一下,大多数情况下,就能搞定日志系统了。
logback
logback是log4j同一个作者设计的,是用来取代后者的日志方案。之所以要额外再设计一个logback,是因为slf4j和log4j通过桥接模式来工作,效率多少受点影响;logback则是直接基于sfl4j规范设置的,完全不需要桥接。因此logback的架构、配置与log4j非常的类似。
slf4j和log4j、logback的更多相关文章
- Java日志框架:SLF4J,Common-Logging,Log4J,Logback说明
Log4j Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台.文件.GUI组件.甚至是套接口服务 器.NT的事件记录器.UNIX Syslog守护进程等 ...
- slf4j log4j logback关系详解和相关用法
slf4j log4j logback关系详解和相关用法 写java也有一段时间了,一直都有用slf4j log4j输出日志的习惯.但是始终都是抱着"拿来主义"的态度,复制粘贴下配 ...
- slf4j,log4j,logback 初步使用
log4j,slf4j,logback简单介绍见 LogBack简易教程 Logback浅析 简单的将,slf4j是一个日志的框架,有各种日志的接口,但是并不包含实际的写日志的方法. log4j,lo ...
- log4j+logback+slf4j+commons-logging的关系与调试(转)
log4j+logback+slf4j+commons-logging的关系与调试 从Log4j迁移到LogBack的理由 http://www.tuicool.com/articles/beeeYv ...
- SpringBoot日志logback-spring.xml分环境log4j logback slf4j区别 springboot日志设置
转载. https://blog.csdn.net/qianyiyiding/article/details/76565810 springboot按照profile进行打印日志log4j logba ...
- slf4j log4j logback log4j2关系详解和相关用法
来源:slf4j log4j logback关系详解和相关用法https://www.cnblogs.com/Sinte-Beuve/p/5758971.html The Simple Logging ...
- Java日志框架SLF4J和log4j以及logback的联系和区别
1.SLF4J(Simple logging Facade for Java) 意思为简单日志门面,它是把不同的日志系统的实现进行了具体的抽象化,只提供了统一的日志使用接口,使用时只需要按照其提供的接 ...
- 拨云见日,彻底弄清楚Java日志框架 log4j, logback, slf4j的区别与联系
log4j 以及 logback, slf4j 官网 日志框架的困惑 作为一个正常的项目,是必须有日志框架的存在的,没有日志,很难追踪一些奇奇怪怪的系统问题. 但是,我们经常在项目的依赖中,见到奇奇怪 ...
- JCL、SLF4J、Log4J、Log4J2、LogBack和JUL之间的关系,你搞清楚了吗?
写在前面 日志组件是我们平时开发过程中必然会用到的组件.在系统中正确的打印日志至少有下面的这些好处: 调试:在程序的开发过程中,必然需要我们不断的调试以达到程序能正确执行的状态 .记录日志可以让开发人 ...
随机推荐
- Maven结构下 properties 读取
Properties properties = new Properties();InputStream in = ClassLoader.class.getResourceAsStream(&quo ...
- 160512、nginx+多个tomcat集群+session共享(windows版)
第一步:下载nginx的windows版本,解压即可使用,点击nginx.exe启动nginx 或cmd命令 1.启动: D:\nginx+tomcat\nginx-1.9.3>start ng ...
- distinct用group by优化
当数据量非常大,在同一个query中计算多个不相关列的distinct时,往往很容易出现数据倾斜现象,导致运行半天都不能得到结果. 比如以下的SQL语句(a, b, c没有相关性): select d ...
- 大文本 mysql es
大文本 mysql es mysql id longText ---> es longText mysqlId 大文本先入mysql,再同步至es: 文本查询逻辑交由es实现: mysq ...
- DK NIO的BUG,例如臭名昭著的epoll bug,它会导致Selector空轮询,最终导致CPU 100%。
NIO的epoll空轮询bug - Lost blog - 博客园 https://www.cnblogs.com/JAYIT/p/8241634.html NIO的epoll空轮询bug JDK ...
- 通过Nginx反向代理实现IP分流
通过Nginx做反向代理来实现分流,以减轻服务器的负载和压力是比较常见的一种服务器部署架构.本文将分享一个如何根据来路IP来进行分流的方法. 根据特定IP来实现分流 将IP地址的最后一段最后一位为0或 ...
- LeetCode_Insertion Sort List
题目:Sort a linked list using insertion sort,即仿照插入排序(直接插入排序)对一个链表排序. 插入排序的思想:总共进行n-1趟排序,在排列第i个元素时,前面的i ...
- 找新朋友---hdu1286(欧拉函数)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1286 欧拉函数:对正整数n,欧拉函数是求少于n的数中与n互质的数的数目: 素数(质数)指在一个大于1的 ...
- Spark Standalone Mode 多机启动 -- 分布式计算系统spark学习(二)(更新一键启动slavers)
捣鼓了一下,先来个手动挡吧.自动挡要设置ssh无密码登陆啥的,后面开搞. 一.手动多台机链接master 手动链接master其实上篇已经用过. 这里有两台机器: 10.60.215.41 启动mas ...
- 14.Iterate a Cursor in the mongo Shell-官方文档摘录
1 迭代游标 } ); while (myCursor.hasNext()) { print(tojson(myCursor.next())); } } ); myCursor.forEach(pri ...