91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

无为县| 通辽市| 攀枝花市| 丰台区| 蓬安县| 锡林浩特市| 邳州市| 深水埗区| 依安县| 浑源县| 临武县| 富民县| 曲松县| 偏关县| 开鲁县| 天水市| 泰宁县| 方正县| 吴堡县| 宁乡县| 镇远县| 大竹县| 贡觉县| 离岛区| 南宁市| 手游| 绥棱县| 昌平区| 逊克县| 十堰市| 宁海县| 台前县| 乐平市| 东阳市| 桂阳县| 海南省| 襄樊市| 株洲县| 穆棱市| 进贤县| 黔南|