logback与log4j比较

程欢欢的博客园 程欢欢的博客园     2022-09-20     227

关键词:

  • 更快的执行速度: 基于我们先前在log4j上的工作,logback 重写了内部的实现,在某些特定的场景上面,甚至可以比之前的速度快上10倍。在保证logback的组件更加快速的同时,同时所需的内存更加少。
  • logback-classic 非常自然的实现了SLF4J:ogback-classic中的longging类自然的实现了SLF4J。当你使用 logback-classic作为底层实现时,涉及到LF4J日记系统的问题你完全不需要考虑。更进一步来说,由于 logback-classic强烈建议使用SLF4J作为客户端日记系统实现,如果需要切换到log4j或者其他,你只需要替换一个jar包即可,不需要去改变那些通过SLF4J API 实现的代码。这可以大大减少更换日记系统的工作量。
  • 自动重新载入配置文件:Logback-classic可以在配置文件被修改后,自动重新载入。这个扫描过程很快,无资源争用,并且可以动态扩展支持在上百个线程之间每秒上百万个调用。它和应用服务器结合良好,并且在JEE环境通用,因为它不会调用创建一个单独的线程来做扫描。
  • 优雅地从I/O错误中恢复:FileAppender和它的子类,包括RollingFileAppender,可以优雅的从I/O错误中恢复。所以,如果一个文件服务器临时宕机,你再也不需要重启你的应用,而日志功能就能正常工作。当文件服务器恢复工作,logback相关的appender就会透明地和快速的从上一个错误中恢复。
  • 自动清除旧的日志归档文件:通过设置TimeBasedRollingPolicy 或者 SizeAndTimeBasedFNATP的 maxHistory 属性,你就可以控制日志归档文件的最大数量。如果你的回滚策略是每月回滚的,并且你希望保存一年的日志,那么只需简单的设置maxHistory属性为12。对于12个月之前的归档日志文件将被自动清除。
  • 自动压缩归档日志文件:RollingFileAppender可以在回滚操作中,自动压缩归档日志文件。压缩通常是异步执行的,所以即使是很大的日志文件,你的应用都不会因此而被阻塞。
  • 配置文件中的条件处理:开发者通常需要在不同的目标环境中变换logback的配置文件,例如开发环境,测试环境和生产环境。这些配置文件大体是一样的,除了某部分会有不同。为了避免重复,logback支持配置文件中的条件处理,只需使用<if>,<then><else>,那么同一个配置文件就可以在不同的环境中使用了。
  • 过滤: Logback拥有远比log4j更丰富的过滤能力。例如,让我们假设,有一个相当重要的商业应用部署在生产环境。考虑到大量的交易数据需要处理,记录级别被设置为WARN,那么只有警告和错误信息才会被记录。现在,想象一下,你在开发环境遇到了一个臭虫,但是在测试平台中却很难发现,因为一些环境之间(生产环境/测试环境)的未知差异。使用log4j,你只能选择在生产系统中降低记录的级别到DEBUG,来尝试发现问题。但是很不幸,这会生成大量的日志记录,让分析变得困难。更重要的是,多余的日志记录会影响到生产环境的性能。使用logback,你可以选择保留只所有用户的WARN级别的日志,而除了某个用户,例如Alice,而她就是问题的相关用户。当Alice登录系统,她就会以DEBUG级别被记录,而其他用户仍然是以WARN级别来记录日志。这个功能,可以通过在配置文件的XML中添加4行。请在相关章节中查找MDCFilter

log4j+logback+slf4j+commons-logging的关系与调试(转)

log4j+logback+slf4j+commons-logging的关系与调试 从Log4j迁移到LogBack的理由 http://www.tuicool.com/articles/beeeYvF 为什么要使用SLF4J而不是Log4J  查看详情

将 Logback 中的应用程序日志与 log4j 中的 Spark 日志分开

】将Logback中的应用程序日志与log4j中的Spark日志分开【英文标题】:SeparatingapplicationlogsinLogbackfromSparkLogsinlog4j【发布时间】:2017-06-2620:05:54【问题描述】:我有一个使用Spark的ScalaMaven项目,我正在尝试使用Logback实现日志记录。我... 查看详情

最全的springboot+logback日志配置教程

...志系统是必不可少的,目前比较流行的日志框架有log4j、logback等,可能大家还不知道,这两个框架的作者是同一个人,Logback旨在作为流行的log4j项目的后续版本,从而恢复log4j离开的位置。另外slf4j(SimpleLoggingFacadeforJava)则是一个... 查看详情

springbootlogback配置详解(代码片段)

一.了解简单地说,Logback是一个Java领域的日志框架。它被认为是Log4J的继承人。Logback主要由三个模块组成:logback-corelogback-classiclogback-accesslogback-core是其它模块的基础设施,其它模块基于它构建,显然,logback-core提供了一些关键... 查看详情

logback的简单使用(代码片段)

logback的使用logback是由log4j的创始人设计的另一个开源日志组件,性能比log4j好LogBack主要分为三个模块:logback-core:其他两个模块的基础模块logback-class:它是log4j的改良版本,完整实现了Slf4jAPIlogback-access:访问模块与... 查看详情

logback的使用

logback的介绍??Logback是由创始人设计的另一个开源日志组件。它分为下面三个模块:1)logback-core??其他两个模块的基础模块2)logback-classic??他是log4j的一个改良版本,同时它完整实现了slf4jAPI,可以很方便地更换成其他日志系统如log... 查看详情

logback日志的配置使用

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

log4j

1、Logback为取代log4j而生   Logback是由log4j创始人CekiGülcü设计的又一个开源日志组件。logback当前分成三个模块:logback-core,logback-classic和logback-access。2、Logback的核心对象:Logger、Appender、Layout    查看详情

log4j+logback+slf4j+commons-logging的关系与调试

参考链接:http://www.cnblogs.com/zhuawang/p/3999235.html一、问题背景  由于现在开源框架日益丰富,好多开源框架使用的日志组件不尽相同。存在着在一个项目中,不同的版本,不同的框架共存。导致日志输出异常混乱。虽然也... 查看详情

日志框架logback相对于log4j的优势

日志框架logback相对于log4j的优势。更快的实现 Logback的内核重写了,在一些关键执行路径上性能提升10倍以上。而且logback不仅性能提升了,初始化内存加载也更小了。 非常充分的测试 Logback经过了几年,数不清小时的... 查看详情

logback的使用和logback.xml详解(代码片段)

一、logback的介绍Logback是由log4j创始人设计的另一个开源日志组件,官方网站:http://logback.qos.ch。它当前分为下面下个模块:logback-core:其它两个模块的基础模块logback-classic:它是log4j的一个改良版本,同时它完整实现了slf4jAPI使你... 查看详情

log4j升级到logback

...现在log4j已经基本上不更新很久了,但实际上升级log4j到logback最大的难度并不在于本身的替换,而是现有大量的三方jar依然使用log4j,以至于无法100%的exclude掉,所以很有可能是无法做到纯粹将log4j升级到logback的。在我们的很多系... 查看详情

logback.xml给变量指定默认值

随着通用日志组件转入Slf4j,logback也变成了默认的日志实现,像log4j一样,logback.xml中也可以使用系统属性或环境变量,如${catalina.home}。在log4j.properties中,如果变量在系统属性和环境变量中找不到的话默认为""空字符串,而到了l... 查看详情

是否有技术原因更喜欢使用 logback 而不是 log4j?

】是否有技术原因更喜欢使用logback而不是log4j?【英文标题】:Aretheretechnicalreasonstopreferusinglogbackinsteadoflog4j?【发布时间】:2010-09-1518:47:51【问题描述】:新项目是否应该使用logback而不是log4j作为日志框架?或者换个说法:\'logba... 查看详情

logback日志

参考技术ALogback继承自log4j。Logback的架构非常的通用,适用不同的使用场景。Logback被分成三个不同的模块:logback-core,logback-classic,logback-access。logback-core是其它两个模块的基础。logback-classic模块可以看作是log4j的一个优化版本... 查看详情

springboot配置logback日志

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

日志框架--logback(代码片段)

logback背景介绍:SLF4J(SimpleLoggingFacadeforJava)是一个日志API接口,SLF4J提供TRACE,DEBUG,INFO,WARN,ERROR五种级别,而log4j和logback就是对SLF4J的具体实现。logback的性能优于log4j。logback-core:其它两个模块的基础模块logback-classic:它是log4j的一... 查看详情

多应用中间的日志使用,log4j,log4j2,logback三个日志框架为例

多应用中间的日志使用,log4j,log4j2,logback三个日志框架为例​​分别使用三个日志框架建好测试​​​​log4j​​​​log4j2​​​​logback​​​​上面的三个同时引入一个应用中​​​​将日志统一使用slf4j标准​​​​不能修改p... 查看详情