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

网友投稿 905 2023-03-25


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

log4j2支持日志的异步打印,日志异步输出的好处在于,使用单独的进程来执行日志打印的功能,可以提高日志执行效率,减少日志功能对正常业务的影响。

异步日志在程序的classpath需要加载disruptor-3.0.0.jar或者更高的版本。

Asynchronous Loggers是一个新增特性在Log4j 2 ,可以实现完全异步也可以和同步混合使用,还可以只异步化Appender,以提升系统性能,官方数据显示混合没有完全异步化效果好。

1,完全异步模式:

这种异步日志方式,不需要修改原来的配置文件,Logger仍然使用 and

只需要在主程序代码开头,加一句系统属性的代码:

System.setProperty("Log4jContextSelector", "org.apache.logging.log4j.core.async.AsyncLoggerContextSelector");

或者设置启动参数:

DLog4jContextSelector=org.apache.logging.log4j.core.async.AsyncLoggerContextSelector

2,异步和非异步混合输出模式

在配置文件中Logger使用,而且可以和混合使用。

immediateFlush="false" append="false">

%d %p %class{1.} [%t] %location %m %ex%n

immediateFlush="false" append="false">

%d %p %class{1.} [%t] %location %m %ex%n

这里需要注意的是,如果使用,includeLocation="true"是必须要设置才会有类路径等一些信息打印出来。

3,只异步化Appender

标签里增加如下标签

然后在或者标签中引用asyncAppender即可,这里includeLocation是增加在标签中的。

无论是完全异步模式还是混合模式,在Appender标签中,immediateFlush属性无论为true或者false,效果都是和设置false是一样的。

4,性能对比

完全异步 > 混合模式 > 只异步化Appender > 同步

5,疑问

使用混合异步模式进行多线程写日志测试的时候,偶尔会出现日志没有写完的情况。是不是主线程执行完CPADTvsE了,不会等待写日志的线程执行完,就把进程给停掉了? 在主线程的最后sleep几秒,就没有再出现日志写不完的情况了。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:移动端效果之IndexList详解
下一篇:浅谈如何使用 webpack 优化资源
相关文章

 发表评论

暂时没有评论,来抢沙发吧~