log4j2支持日志的异步打印,日志异步输出的好处在于,使用单独的进程来执行日志打印的功能,可以提高日志执行效率,减少日志功能对正常业务的影响。
异步日志在程序的classpath需要加载disruptor-3.0.0.jar或者更高的版本。
Asynchronous Loggers是一个新增特性在Log4j 2 ,可以实现完全异步也可以和同步混合使用,还可以只异步化Appender,以提升系统性能,官方数据显示混合没有完全异步化效果好。
1,完全异步模式:
这种异步日志方式,不需要修改原来的配置文件,Logger仍然使用<root> and <logger>
只需要在主程序代码开头,加一句系统属性的代码:
System.setProperty("Log4jContextSelector", "org.apache.logging.log4j.core.async.AsyncLoggerContextSelector");
或者设置启动参数:
-DLog4jContextSelector=org.apache.logging.log4j.core.async.AsyncLoggerContextSelector
2,异步和非异步混合输出模式
在配置文件中Logger使用<asyncRoot> 或 <asyncLogger>,而且<asyncRoot> 或 <asyncLogger>可以和<root> 或 <logger>混合使用。
<!--[if !supportLineBreakNewLine]-->
<!--[endif]-->
<?xml version="1.0" encoding="UTF-8"?>
<!-- No need to set system property "Log4jContextSelector" to any value
when using <asyncLogger> or <asyncRoot>. -->
<Configuration status="WARN">
<Appenders>
<!-- Async Loggers will auto-flush in batches, so switch off immediateFlush. -->
<RandomAccessFile name="RandomAccessFile" fileName="asyncWithLocation.log"
immediateFlush="false" append="false">
<PatternLayout>
<Pattern>%d %p %class{1.} [%t] %location %m %ex%n</Pattern>
</PatternLayout>
</RandomAccessFile>
</Appenders>
<Loggers>
<!-- pattern layout actually uses location, so we need to include it -->
<AsyncLogger name="com.foo.Bar" level="trace" includeLocation="true">
<AppenderRef ref="RandomAccessFile"/>
</AsyncLogger>
<Root level="info" includeLocation="true">
<AppenderRef ref="RandomAccessFile"/>
</Root>
</Loggers>
</Configuration>
这里需要注意的是,如果使用<asyncRoot> 或 <asyncLogger>,includeLocation="true"是必须要设置才会有类路径等一些信息打印出来。
3,只异步化Appender
在<Appenders>标签里增加如下<Async>标签
<!--[if !supportLineBreakNewLine]-->
<!--[endif]-->
<Async name="asyncAppender" includeLocation="true">
<AppenderRef ref="RandomAccessFile"/>
</Async>
然后在<Root>或者<Logger>标签中引用asyncAppender即可,这里includeLocation是增加在<Async>标签中的。
<!--[if !supportLineBreakNewLine]-->
<!--[endif]-->
<Root level="info">
<AppenderRef ref="RandomAccessFile"/>
</Root>
无论是完全异步模式还是混合模式,在Appender标签中,immediateFlush属性无论为true或者false,效果都是和设置false是一样的。
4,性能对比
完全异步 > 混合模式 > 只异步化Appender > 同步
5,疑问
使用混合异步模式进行多线程写日志测试的时候,偶尔会出现日志没有写完的情况。是不是主线程执行完了,不会等待写日志的线程执行完,就把进程给停掉了?在主线程的最后sleep几秒,就没有再出现日志写不完的情况了。
首先disruptor是特别适用于对时间高度敏感的多线程应用。如果app对时间不敏感完全可以不用disruptor 而只用array blocking queue. 再如果废了好大劲挣回来30毫秒,结果被一个数据库连接耗掉1秒,也没必要用。所以搞清楚适用的环境很重要。
其次这个技术其实很酷的。最酷的地方不是ring buffer 而是想到直接用CPU指令做CAS. Ring buffer是做了工程级别的优化,对于CPU branch prediction更友好。也就是我们说的cache friendly。其他的别人没提到的好处是可以replay ,这样对daily regression test很方便。
实际适用的例子随便举两个。 一个是实时的Reuters 市场数据接收,redistribute 到其他进程或者线程。另一个是如果algo model 决定place order or pull order from the market,就需要以最快的方式给市场发指令。在一个是比较复杂一点:多个ring buffer穿起来形成一个小型producer consumer 工作流,这个用的人应该不算多我就不白虎了。
相关推荐
Java中的Log4j 2日志框架是一款广泛应用于企业级应用开发的日志处理工具,它在Log4j 1.x的基础上进行了大量的优化和改进,提供了更高效、更灵活的日志记录功能。Log4j 2.23.0是其最新的稳定版本,包含了对性能、安全...
Log4j2是Apache软件基金会开发的日志框架Log4j的升级版,它具有更高的性能、灵活性和可配置性。Log4j2支持多种日志记录级别(如DEBUG、INFO、WARN、ERROR),并允许通过XML、JSON、YAML或纯Java配置文件进行灵活配置...
Log4j2异步日志打印机制详解 Log4j2是一个功能强大的日志记录库,它提供了异步日志打印机制,以提高日志记录效率和减少对正常业务的影响。下面将详细介绍Log4j2异步日志打印机制的原理和实现方法。 什么是异步日志...
Log4j2是一款广泛使用的Java日志记录框架,它的核心在于提供高效、灵活的日志记录...总的来说,这两个jar文件是构建和运行Log4j2日志系统的基础,它们共同确保了日志记录的效率和灵活性,是Java开发者必备的工具之一。
本篇文章将深入探讨如何在Spring 5中整合Log4j2日志工具,以实现高效、灵活的日志管理。 首先,我们来理解Spring 5和Log4j2的基本概念。Spring 5是Spring框架的一个主要版本,提供了更强大的功能和性能优化,支持...
在SpringBoot应用中使用Log4j2,需要在`pom.xml`中添加Log4j2的依赖,并在`application.properties`或`log4j2.xml`/`log4j2.json`文件中进行相应配置。 **Log4j2的配置** 1. **Maven依赖**:在`pom.xml`中添加Log4...
Log4j2 是一个强大的日志记录框架,提供了灵活的日志配置,包括异步日志记录,性能提升,以及丰富的日志输出格式。它可以通过XML、JSON或YAML配置文件来定义日志级别、输出目的地和格式。 **整合过程** 1. **环境...
- **性能改进**:Log4j2 引入了新的并发模型和异步处理机制,可以显著提高日志记录的效率。 - **配置文件格式**:Log4j2 支持 XML、JSON 和 YAML 等多种配置文件格式,相比 Log4j1.x 更加灵活。 #### 1.4 API Log4...
Log4j 2是其最新版本,提供了许多改进和增强功能,如异步日志记录、插件体系结构和动态日志配置。 标题中的"ApacheLog4j_Win.zip"暗示这是一个针对Windows操作系统的Apache Log4j漏洞验证工具。这意味着该压缩包...
2018年4月30日发布的“log4j-1.2.17.jar”是该版本的最新更新,主要服务于那些尚未迁移至Log4j 2.x或其它日志框架的项目。本文将深入探讨Log4j 1.2.17的核心特性、使用方法以及它在软件开发中的重要性。 1. **核心...
3. **异步日志记录**:Log4j2引入了异步日志记录器,通过使用线程池和LMAX Disruptor库,能够实现无锁日志写入,进一步提升了性能。 4. **丰富的插件体系**:Log4j2拥有一个强大的插件系统,可以支持多种日志输出...
在本项目中,我们主要探讨的是如何在Spring Boot 2框架下实现多数据源配置,同时结合MyBatis、MySQL数据库、Log4j2日志系统以及Swagger2 API文档工具进行应用开发。以下是对这些技术栈的详细说明: **Spring Boot 2...
日志介绍 日志的作用和...log4j2 "log4j2的日志框架 log4j2的配置 异步日志的使用" spring整合log "依赖的选择 日志的配置文件" SpringBoot日志 "SpringBoot日志 中间转换包统一日志框架 SpringBoot修改日志的默认配置
1. **Log4e介绍**:Log4e是基于Log4j的扩展,专为Android平台设计,提供更丰富的功能,如异步日志记录、自定义日志级别、性能优化等。它使得在Android应用中添加和管理日志变得更加简单和高效。 2. **Eclipse集成...
Log4net是.NET Framework下的一款强大、灵活的日志记录工具,类似于Java中的log4j,它提供了丰富的配置选项和多种输出方式,使得在C#等.NET语言中实现操作记录变得极其便利。 首先,我们需要理解log4net的核心概念...
2. **C#中的Log4net使用** - 在C#项目中引入Log4net,首先需要通过NuGet包管理器或者手动下载并添加引用到项目中。 - 配置Log4net通常在应用程序的配置文件(如app.config)中完成,定义日志输出级别、目标和格式...
本篇将详细讲解Spring MVC 4.2.1版本的核心概念以及与Log4j2日志库的结合使用。 1. **Spring MVC 框架核心组件** - **DispatcherServlet**:作为Spring MVC的前端控制器,负责接收请求并分发到相应的处理器。 - *...
在C#编程中,事件是多线程...总的来说,理解和熟练运用事件、委托和事件处理程序是C#编程中必不可少的技能,特别是在构建交互式用户界面和实现异步通信时。通过这种方式,我们可以创建出更加灵活和可扩展的应用程序。
2. 配置日志:创建日志配置文件,如`log4j.properties`或`logback.xml`。在这里,我们可以设置日志的级别(DEBUG、INFO、WARN、ERROR等)、输出目的地(控制台、文件、邮件等)以及布局格式。 3. 引入日志API:在...
`spdlog`是一个轻量级、快速的C++11日志库,支持多种输出格式,如控制台、文件、甚至是网络。它的特点是高度可定制化,可以方便地调整日志级别,同时提供了异步日志记录以提高性能。在项目中引入`spdlog`,可以简化...