一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - log4j2日志異步打印(實例講解)

log4j2日志異步打印(實例講解)

2021-01-23 12:13wunan23的日志 Java教程

下面小編就為大家?guī)硪黄猯og4j2日志異步打印(實例講解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

log4j2支持日志異步打印,日志異步輸出的好處在于,使用單獨的進程來執(zhí)行日志打印的功能,可以提高日志執(zhí)行效率,減少日志功能對正常業(yè)務(wù)的影響。

異步日志在程序的classpath需要加載disruptor-3.0.0.jar或者更高的版本。

Asynchronous Loggers是一個新增特性在Log4j 2 ,可以實現(xiàn)完全異步也可以和同步混合使用,還可以只異步化Appender,以提升系統(tǒng)性能,官方數(shù)據(jù)顯示混合沒有完全異步化效果好。

1,完全異步模式:

這種異步日志方式,不需要修改原來的配置文件,Logger仍然使用<root> and <logger>

只需要在主程序代碼開頭,加一句系統(tǒng)屬性的代碼:

?
1
System.setProperty("Log4jContextSelector", "org.apache.logging.log4j.core.async.AsyncLoggerContextSelector");

或者設(shè)置啟動參數(shù):

?
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"是必須要設(shè)置才會有類路徑等一些信息打印出來。

3,只異步化Appender

在<Appenders>標(biāo)簽里增加如下<Async>標(biāo)簽

?
1
2
3
<Async name="asyncAppender" includeLocation="true">
<AppenderRef ref="RandomAccessFile"/>
</Async>

然后在<Root>或者<Logger>標(biāo)簽中引用asyncAppender即可,這里includeLocation是增加在<Async>標(biāo)簽中的。

?
1
2
3
<Root level="info">
<AppenderRef ref="RandomAccessFile"/>
</Root>

無論是完全異步模式還是混合模式,在Appender標(biāo)簽中,immediateFlush屬性無論為true或者false,效果都是和設(shè)置false是一樣的。

4,性能對比

完全異步 > 混合模式 > 只異步化Appender > 同步

5,疑問

使用混合異步模式進行多線程寫日志測試的時候,偶爾會出現(xiàn)日志沒有寫完的情況。是不是主線程執(zhí)行完了,不會等待寫日志的線程執(zhí)行完,就把進程給停掉了? 在主線程的最后sleep幾秒,就沒有再出現(xiàn)日志寫不完的情況了。

以上這篇log4j2日志異步打印(實例講解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持服務(wù)器之家。

原文鏈接:http://blog.163.com/wunan_23/blog/static/195562320201741045941799/

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产偷窥女洗浴在线观看亚洲 | 韩国免费特一级毛片 | 免费看男女污污完整版 | 亚洲AV无码一区二区三区乱子伦 | 毛片的网站 | 婷婷色六月 | 国产一区国产二区国产三区 | 午夜影院费试看黄 | 国产精品久久久久无毒 | 精品亚洲视频在线观看 | 欧美精品一区二区三区免费播放 | 亚洲欧美日韩综合在线播放 | 青青青草国产线观 | 国产成人福利免费视频 | 日产乱码卡1卡2卡三卡四在线 | 国产一区二区三区高清 | 日韩精品中文字幕久久 | 清清草在线视频 | 麻豆视频网| 国产精品久久久久久久久99热 | 视频一区二区在线 | 男人狂躁女人下面的视频免费 | 韩国男女做性全过程视频 | 亚欧洲乱码视频一二三区 | 国产精品免费久久久久影院小说 | 亚洲精品第一国产综合高清 | 久久AV喷吹AV高潮欧美 | 天天草人人草 | 日韩成a人片在线观看日本 日韩不卡一区二区 | 视频在线观看大片 | 韩国美女vip内部2020 | 国产一区视频在线免费观看 | 久久水蜜桃亚洲AV无码精品偷窥 | 亚洲熟区| 精品福利一区二区免费视频 | 秋霞午夜伦午夜高清福利片 | 九色PORNY蝌蚪视频首页 | 白丝校花被扒开双腿喷水小说 | 国产日产精品久久久久快鸭 | 日本嫩小xxxxhd | 91精品国产色综合久久 |