之前的日志框架基本都實現了AsyncAppender,被證明對性能的提升作用非常明顯。
在log4j2日志框架中,增加了對Logger的異步實現。那么這一步的解耦,意義何在呢?
如圖,按我目前的理解:異步Logger是讓業務邏輯把日志信息放入Disruptor隊列后可以直接返回(無需等待“掛載的各個Appender”都取走數據)
優點:更高吞吐、調用log方法更低的延遲。
缺點:異常處理麻煩、 可變日志消息問題、更大的CPU開銷、需要等待“最慢的Appender”消費完成。
異步Logger會使用Disruptor做高吞吐隊列,異步Appender會使用ArrayBlockingQueue做隊列。
異步Logger與異步Appender都可以設置“隊列滿了之后的策略”,我個人建議都設置為“按日志級別部分丟棄”。
2 啟用
1,全局啟用異步Logger方案一
JVM啟動參數(boot.ini)加上“-DLog4jContextSelector=org.apache.logging.log4j.core.async.AsyncLoggerContextSelector”
2,全局啟用異步Logger方案二
classpath中添加文件“log4j2.component.properties”,文件增加以下內容:
“Log4jContextSelector=org.apache.logging.log4j.core.async.AsyncLoggerContextSelector”
3,手工指定部分Logger采用異步方式
log4j2.xml配置文件中使用AsyncRoot/AsyncLogger替代Root/Logger
(上述3種方式任選其一即可,不要同時采用)
以上這篇log4j2異步Logger(詳解)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持服務器之家。
原文鏈接:http://blog.csdn.net/heyutao007/article/details/72773077