1 異步Logger的意義
成都創(chuàng)新互聯(lián)專注于企業(yè)營銷型網(wǎng)站建設(shè)、網(wǎng)站重做改版、治多網(wǎng)站定制設(shè)計、自適應(yīng)品牌網(wǎng)站建設(shè)、H5建站、商城網(wǎng)站開發(fā)、集團公司官網(wǎng)建設(shè)、外貿(mào)營銷網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為治多等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。之前的日志框架基本都實現(xiàn)了AsyncAppender,被證明對性能的提升作用非常明顯。
在log4j2日志框架中,增加了對Logger的異步實現(xiàn)。那么這一步的解耦,意義何在呢?
如圖,按我目前的理解:異步Logger是讓業(yè)務(wù)邏輯把日志信息放入Disruptor隊列后可以直接返回(無需等待“掛載的各個Appender”都取走數(shù)據(jù))
優(yōu)點:更高吞吐、調(diào)用log方法更低的延遲。
缺點:異常處理麻煩、 可變?nèi)罩鞠栴}、更大的CPU開銷、需要等待“最慢的Appender”消費完成。
異步Logger會使用Disruptor做高吞吐隊列,異步Appender會使用ArrayBlockingQueue做隊列。
異步Logger與異步Appender都可以設(shè)置“隊列滿了之后的策略”,我個人建議都設(shè)置為“按日志級別部分丟棄”。
2 啟用
1,全局啟用異步Logger方案一
JVM啟動參數(shù)(boot.ini)加上“-DLog4jContextSelector=org.apache.logging.log4j.core.async.AsyncLoggerContextSelector”
2,全局啟用異步Logger方案二
classpath中添加文件“l(fā)og4j2.component.properties”,文件增加以下內(nèi)容:
“Log4jContextSelector=org.apache.logging.log4j.core.async.AsyncLoggerContextSelector”
3,手工指定部分Logger采用異步方式
log4j2.xml配置文件中使用AsyncRoot/AsyncLogger替代Root/Logger
(上述3種方式任選其一即可,不要同時采用)
以上這篇log4j2異步Logger(詳解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持創(chuàng)新互聯(lián)。