您好,登錄后才能下訂單哦!
1 異步Logger的意義
之前的日志框架基本都實現了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(詳解)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。