`
kavy
  • 浏览: 868286 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

log4j2日志异步打印

 
阅读更多

 

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 工作流,这个用的人应该不算多我就不白虎了。
http://ifeve.com/disruptor/
 
分享到:
评论

相关推荐

    log4j2日志异步打印(实例讲解)

    下面小编就为大家带来一篇log4j2日志异步打印(实例讲解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

    使用log4j2实现日志数据脱敏

    使用log4j2实现日志数据脱敏

    java代码实例-日志规范史上最全java日志攻略(附教程)

    日志介绍 日志的作用和...log4j2 "log4j2的日志框架 log4j2的配置 异步日志的使用" spring整合log "依赖的选择 日志的配置文件" SpringBoot日志 "SpringBoot日志 中间转换包统一日志框架 SpringBoot修改日志的默认配置

    httppost请求的完美封装

    默认不打印log * 5.此处的接口都是使用的三方接口:知乎地址:https://www.zhihu.com/question/39479153(未使用) * 此处可以将自己的ip接口放上去。 * * 说明:我的qq号:1457521527;欢迎互相学习~ * @author ...

    高频大数据解决方案.pptx

    VoltDB管理和监控 Nagios 脚本 Logs to Log4j JMX VoltDB 企业管理器 每一个节点都有一个内置网络服务器 特殊的系统程序 高频大数据解决方案全文共28页,当前为第12页。 VoltDB的一个典型架构 ERP CRM HR Orders ...

    详细设计说明书

    用例主要包括购卡支付、购卡冲正、折扣查询、购卡历史记录查询等, 由于采用异步通信方式将支付、冲正分为请求和响应两个子用例。 用例说明: 购卡支付请求:该用例说明用户通过短消息、wap、web等通信接入手段...

    最新支付宝手机网站支付源代码,安全可靠

    格式:年[4位]月[2位]日[2位]小时[2位 24小时制]分[2位]秒[2位],如:20071001131313 输出:String 时间格式化结果 Function DelStr(Str) 功能:过滤特殊字符 输入:String Str 要被过滤的字符串 输出:String 已被...

    Oracle9i的init.ora参数中文说明

    说明: 使用字节或码点语义来指定新列的创建, 如 char, varchar2, clob, nchar, nvarchar2, nclob 列。各种字符集对字符都有各自的定义。在客户机和服务器上使用同一字符集时, 应以该字符集所定义的字符来衡量字符串...

    C#程序开发范例宝典(第2版).part12

    1.1 菜单应用实例 2 实例001 带历史信息的菜单 2 实例002 菜单动态合并 3 实例003 像开始菜单一样漂亮的菜单 4 实例004 任务栏托盘菜单 4 实例005 可以拉伸的菜单界面 5 实例006 级联菜单 6 1.2 工具栏设计 6...

    C#程序开发范例宝典(第2版).part08

    1.1 菜单应用实例 2 实例001 带历史信息的菜单 2 实例002 菜单动态合并 3 实例003 像开始菜单一样漂亮的菜单 4 实例004 任务栏托盘菜单 4 实例005 可以拉伸的菜单界面 5 实例006 级联菜单 6 1.2 工具栏设计 6...

    C#程序开发范例宝典(第2版).part13

    1.1 菜单应用实例 2 实例001 带历史信息的菜单 2 实例002 菜单动态合并 3 实例003 像开始菜单一样漂亮的菜单 4 实例004 任务栏托盘菜单 4 实例005 可以拉伸的菜单界面 5 实例006 级联菜单 6 1.2 工具栏设计 6...

    C#程序开发范例宝典(第2版).part02

    1.1 菜单应用实例 2 实例001 带历史信息的菜单 2 实例002 菜单动态合并 3 实例003 像开始菜单一样漂亮的菜单 4 实例004 任务栏托盘菜单 4 实例005 可以拉伸的菜单界面 5 实例006 级联菜单 6 1.2 工具栏设计 6...

    asp.net知识库

    体验.net2.0的优雅(四):Provider、策略、控制反转和依赖注入 泛型最佳实践 asp.net 2.0下嵌套masterpage页的可视化编辑 C# 2.0与泛型 动态调用对象的属性和方法——性能和灵活性兼备的方法 泛型技巧系列:用泛型...

Global site tag (gtag.js) - Google Analytics