最近想推动项目组在新产品/新项目上使用logback,于是打算了解下logback
1.官方手册 http://logback.qos.ch/manual/,介绍的非常详细。
2.基本上只需要引入如下三个jar,就可以满足与log4j类似的日志特性了。
logback-classic-1.1.8.jar
logback-core-1.1.8.jar
slf4j-api-1.7.22.jar
3.翻阅了下源码进行了初步梳理
4.下一步打算通过阅读官方手册+阅读源码,整理一份配置文件的sample
//TODO
5.logback与log4j callAppender方法的差异分析
a.log4j的callAppender方法对for循环中获取的logger使用synchronize关键字进行修饰; logback中没有使用sychronized
b.log4j和logback的addAppender/removeAppender方法都有sychronized关键字进行修饰;logback的detachAppender没有使用synchronized关键字修饰
c.log4j使用Vector存放appender;logback使用CopyOnWriteArrayList存放appender
d.log4j在callAppender方法中如果不使用synchronized,则并发情况下会持续其他线程调用addAppender/removeAppender等方法,改变Vector中存放的appener。由于遍历appender使用的是for(int i...),会导致出现越界(数组变小)或者未能访问后续增加的appender
e.log4j由于对Logger使用了synchronized修饰,当多个线程并发访问同一个logger时,会出现等待锁的情况,存在性能风险
f.logback因为使用CopyOnWriteArrayList存放appender,且遍历appender使用的是foreach,可以避免出现越界(数组变小)和未能方位后续追加成果的appender。
g.CopyOnWriteArrayList的iterator返回的是COWIterator对象,每次的hasNext都是使用构造时传入的数组对象(addIfAbsent和remove执行成果后会改变这个数组)的length跟cursor进行判断,故可以避免越界风险,也可以避免没有及时访问到新追加成功的元素(appender)
ps:
a.log4j在初始化时,通过LogManager创建了一个Hierarchy实例,所有的logger都存放在Hierarchy的HashTable中,并根据包路径层次关系构建父子关系
b.logback通过StaticLoggerBinder初始化获取单实例,并通过其defaultLoggerContext属性来指向LoggerContext实例,所有的logger都存放在LoggerContext的ConcurrentHashMap中,并根据包路径层次关系构建父子关系
- 大小: 137 KB
分享到:
相关推荐
Logback 是一个流行的 Java 日志框架,由 Ceki Gülcü 创建,他是早期日志框架 Log4j 的主要开发者。Logback 是为了提供更高效、更灵活的日志记录解决方案而设计的,它不仅继承了 Log4j 的优点,还解决了一些性能和...
Logback 是一款广泛使用的日志记录框架,由 Ceki Gülcü 创建,作为其先前作品 Log4j 的改进版。这个压缩包包含了实现 Logback 功能所需的几个关键组件,以及一个配置文件,使得用户能够方便地管理和记录应用程序的...
**日志框架Logback** 日志是任何软件系统中至关重要的组成部分,它为开发者提供了运行时的调试信息、错误报告以及性能分析数据。在Java世界里,Logback是一款高效、可配置的日志记录框架,由Ceki Gülcü(也是log4...
**日志框架Logback简介** Logback 是一个用于日志记录的开源框架,由 Ceki Gülcü(也是 Log4j 的创始人)设计并开发。它作为 Log4j 的升级版,提供了更高的性能和更丰富的功能。Logback 分为三个主要组件:...
Logback 是一个在Java应用程序中广泛使用的日志记录框架,它是对早期的log4j框架的一个升级和扩展。Logback 提供了高效、灵活的日志记录解决方案,支持多种日志级别,如DEBUG、INFO、WARN、ERROR等,帮助开发者调试...
在这里,我们关注的是SLF4J的API库`slf4j-api-1.7.26.jar`,以及Logback的两个核心组件`logback-core-1.2.3.jar`和`logback-classic-1.2.3.jar`,以及配置文件`logback.xml`。 首先,`slf4j-api-1.7.26.jar`是SLF4J...
免费获取Logback所需的jar包 打包合集 让你少走弯路 一.logback简介 1.logback: Logback是由log4j创始人设计的另一个开源日志组件。(好的日志记录方式可以提供我们足够多的定位错误的依据)。 2.主要有三个模块...
分享的文件包括Logback的相关jar包和核心配置文件。 Logback是由log4j创始人设计的另一个开源日志组件,基于slf4j的日志规范实现的框架,性能比log4j要好。 Logback主要分为三个技术模块: logback-core:该模块为...
**标题:“logback”** **描述:** 在IT领域,logback是一个广泛使用的日志记录框架,由Ceki Gülcü创建,它是log4j的后续项目,旨在提供更高的性能和更灵活的配置。Logback的主要目标是提高日志处理的效率,同时...
标题“logback1.2.3”和描述中的文件名暗示了这是一个关于Logback日志框架的版本1.2.3的资源包,其中包含了Logback的经典实现(logback-classic)和核心库(logback-core),以及Simple Logging Facade for Java ...
**Slf4j与Logback简介** Slf4j(Simple Logging Facade for Java)是一个日志门面,它提供了一个统一的API,允许开发者选择合适的日志框架,如Logback、Log4j等,而无需修改代码。Slf4j的主要目标是为各种日志框架...
《logback类库详解》 在Java开发领域,日志管理是不可或缺的一部分,它帮助开发者追踪应用程序的运行状态,定位和解决问题。Logback是其中一个广泛使用的日志框架,由Ceki Gülcü创建,它是对log4j的一个升级版本...
Logback允许用户通过实现`ch.qos.logback.core.UnsynchronizedAppenderBase`或`ch.qos.logback.core.AppenderBase`类并覆盖`append()`方法来自定义日志处理逻辑。例如,我们可以解析JSON格式的日志,从中提取关键...
本文将详细介绍logback的三个核心jar文件:logback-classic-1.1.7.jar、logback-core-1.1.7.jar和slf4j-api-1.7.21.jar,以及它们在日志处理中的作用。 1. **logback-classic-1.1.7.jar** logback-classic是...
Logback 是一个专门为Java应用程序设计的日志框架,由log4j的创始人Ceki Gülcü设计,旨在提高日志处理的效率和灵活性。它在性能和资源消耗方面优于log4j和其他日志系统,提供了许多独特的特性,如Marker、参数化...
**logback-1.1.2源码包详解** **一、logback介绍** Logback 是一个用于日志记录的开源框架,由 Ceki Gülcü(也创建了广泛使用的 log4j)开发。它是对 log4j 的升级,旨在提供更高的性能、更灵活的配置以及更好的...
2. **组件结构**:Logback 主要由三个核心组件构成:Logback-Core、Logback-Classic 和 Logback-Appender。Logback-Core 提供基础架构,Logback-Classic 实现了 SLF4J(Simple Logging Facade for Java)接口,而 ...
Logback 主要分为三个组件:logback-core、logback-classic 和 logback-access。logback-core 提供基础架构,而 logback-classic 实现了经典的 SLF4J(Simple Logging Facade for Java)API,并包含一个名为...
"logback-classic-"和"logback-core-1.2"分别代表Logback的经典日志实现和核心库,它们是Logback框架的重要组成部分。 **文件名称列表** - "logback-core-1.2.3.jar": 这是Logback的核心组件,提供了日志记录的...
Logback 中文手册,清晰版. 简单地说,Logback 是一个 Java 领域的日志框架。它被认为是 Log4J 的继承人。 Logback 主要由三个模块组成: logback-core logback-classic logback-access