log4j2支持日志的異步打印,日志異步輸出的好處在于,使用單獨的進程來執行日志打印的功能,可以提高日志執行效率,減少日志功能對正常業務的影響。
異步日志在程序的classpath需要加載disruptor-3.0.0.jar或者更高的版本。
Asynchronous Loggers是一個新增特性在Log4j 2 ,可以實現完全異步也可以和同步混合使用,還可以只異步化Appender,以提升系統性能,官方數據顯示混合沒有完全異步化效果好。
1,完全異步模式:
這種異步日志方式,不需要修改原來的配置文件,Logger仍然使用<root> and <logger>
只需要在主程序代碼開頭,加一句系統屬性的代碼:
1
|
System.setProperty("Log4jContextSelector", "org.apache.logging.log4j.core.async.AsyncLoggerContextSelector"); |
或者設置啟動參數:
1
|
DLog4jContextSelector=org.apache.logging.log4j.core.async.AsyncLoggerContextSelector |
2,異步和非異步混合輸出模式
在配置文件中Logger使用<asyncRoot> 或 <asyncLogger>,而且<asyncRoot> 或 <asyncLogger>可以和<root> 或 <logger>混合使用。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
<? 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>標簽
1
2
3
|
< Async name = "asyncAppender" includeLocation = "true" > < AppenderRef ref = "RandomAccessFile" /> </ Async > |
然后在<Root>或者<Logger>標簽中引用asyncAppender即可,這里includeLocation是增加在<Async>標簽中的。
1
2
3
|
< Root level = "info" > < AppenderRef ref = "RandomAccessFile" /> </ Root > |
無論是完全異步模式還是混合模式,在Appender標簽中,immediateFlush屬性無論為true或者false,效果都是和設置false是一樣的。
4,性能對比
完全異步 > 混合模式 > 只異步化Appender > 同步
5,疑問
使用混合異步模式進行多線程寫日志測試的時候,偶爾會出現日志沒有寫完的情況。是不是主線程執行完了,不會等待寫日志的線程執行完,就把進程給停掉了? 在主線程的最后sleep幾秒,就沒有再出現日志寫不完的情況了。
以上這篇log4j2日志異步打印(實例講解)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持服務器之家。
原文鏈接:http://blog.163.com/wunan_23/blog/static/195562320201741045941799/