您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關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>混合使用。
<?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>標簽
<Async name="asyncAppender" includeLocation="true"> <AppenderRef ref="RandomAccessFile"/> </Async>
然后在<Root>或者<Logger>標簽中引用asyncAppender即可,這里includeLocation是增加在<Async>標簽中的。
<Root level="info"> <AppenderRef ref="RandomAccessFile"/> </Root>
無論是完全異步模式還是混合模式,在Appender標簽中,immediateFlush屬性無論為true或者false,效果都是和設置false是一樣的。
4,性能對比
完全異步 > 混合模式 > 只異步化Appender > 同步
5,疑問
使用混合異步模式進行多線程寫日志測試的時候,偶爾會出現日志沒有寫完的情況。是不是主線程執行完了,不會等待寫日志的線程執行完,就把進程給停掉了? 在主線程的最后sleep幾秒,就沒有再出現日志寫不完的情況了。
感謝各位的閱讀!關于“log4j2中日志異步打印的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。