Log4j2的Policy觸發策略與Strategy滾動策略配置詳解

轉載:https://blog.csdn.net/ThinkWon/article/details/101628222

Policy是用來控制日誌文件何時(When)進行滾動的;Strategy是用來控制日誌文件如何(How)進行滾動的。

如果配置的是RollingFile或RollingRandomAccessFile,則必須配置一個Policy。

Policy觸發策略
SizeBasedTriggeringPolicy
基於日誌文件大小的觸發策略。單位有:KB,MB,GB

<SizeBasedTriggeringPolicy size="10 MB"/>

CronTriggeringPolicy

基於Cron表達式的觸發策略,很靈活。

<CronTriggeringPolicy schedule="0/5 * * * * ?" />

TimeBasedTriggeringPolicy
基於時間的觸發策略。該策略主要是完成周期性的log文件封存工作。有兩個參數:

interval,integer型,指定兩次封存動作之間的時間間隔。這個配置需要和filePattern結合使用,filePattern日期格式精確到哪一位,interval也精確到哪一個單位。注意filePattern中配置的文件重命名規則是%d{yyyy-MM-dd HH-mm-ss}-%i,最小的時間粒度是ss,即秒鐘。
TimeBasedTriggeringPolicy默認的size是1,結合起來就是每1秒鐘生成一個新文件。如果改成%d{yyyy-MM-dd HH},最小粒度爲小時,則每一個小時生成一個文件

modulate,boolean型,說明是否對封存時間進行調製。若modulate=true, 則封存時間將以0點爲邊界進行偏移計算。比如,modulate=true,interval=4hours, 那麼假設上次封存日誌的時間爲03:00,則下次封存日誌的時間爲04:00, 之後的封存時間依次爲08:00,12:00,16:00

簡單示例:

<?xml version="1.0" encoding="UTF-8"?>
<Configuration>
    <Appenders>
        <RollingRandomAccessFile name="File" fileName="./log/app.log"
                                 filePattern="./log/app-%d{yyyy-MM-dd HH-mm}-%i.log">
            <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss,SSS} [%t] %-5level %logger{0} - %msg%n" charset="UTF-8"/>
            <Policies>
                <!-- 每 5s 翻滾一次 -->
                <!--<CronTriggeringPolicy schedule="0/5 * * * * ?"/>-->
                <!--根據當前filePattern配置,日誌文件每3分鐘滾動一次-->
                <TimeBasedTriggeringPolicy interval="3"/>
                <!--日誌文件大於10 MB滾動一次-->
                <SizeBasedTriggeringPolicy size="10 MB"/>
            </Policies>
            <!--保存日誌文件個數-->
            <DefaultRolloverStrategy max="10"/>
        </RollingRandomAccessFile>
    </Appenders>
    <Loggers>
        <Root level="info">
            <AppenderRef ref="File"/>
        </Root>
    </Loggers>
</Configuration>

Strategy滾動策略

  1. DefaultRolloverStrategy

    默認滾動策略

    常用參數:max,保存日誌文件的最大個數,默認是7,大於此值會刪除舊的日誌文件

<!--保存日誌文件個數-->
<DefaultRolloverStrategy max="10"/>

2.DirectWriteRolloverStrategy

日誌直接寫入由文件模式表示的文件。

 這兩個Strategy都是控制如何進行日誌滾動的,平時大部分用DefaultRolloverStrategy就可以了。

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章