中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

log4j2中日志異步打印的示例分析

發布時間:2021-08-05 14:37:05 來源:億速云 閱讀:299 作者:小新 欄目:編程語言

這篇文章給大家分享的是有關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中日志異步打印的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武胜县| 墨竹工卡县| 吉林省| 东丽区| 确山县| 轮台县| 石林| 迭部县| 南阳市| 桃园县| 大宁县| 蓬安县| 连南| 吉林市| 偏关县| 安义县| 城口县| 昭通市| 大同县| 内乡县| 阜南县| 烟台市| 卢氏县| 神农架林区| 昭平县| 三台县| 蒙阴县| 绵竹市| 广饶县| 怀仁县| 囊谦县| 拜城县| 西峡县| 高雄市| 平果县| 兖州市| 阿拉善左旗| 灵寿县| 泰宁县| 准格尔旗| 绥宁县|