天天看點

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

  • ​​Policy觸發政策​​
  • ​​SizeBasedTriggeringPolicy​​
  • ​​CronTriggeringPolicy​​
  • ​​TimeBasedTriggeringPolicy​​
  • ​​Strategy滾動政策​​

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 KB"/>
            </Policies>
            <!--儲存日志檔案個數-->
            <DefaultRolloverStrategy max="10"/>
        </RollingRandomAccessFile>
    </Appenders>
    <Loggers>
        <Root level="info">
            <AppenderRef ref="File"/>
        </Root>
    </Loggers>
</Configuration>      

Strategy滾動政策

  1. DefaultRolloverStrategy

    預設滾動政策

    常用參數:max,儲存日志檔案的最大個數,預設是7,大于此值會删除舊的日志檔案。

  1. <!--儲存日志檔案個數--><DefaultRolloverStrategy max="10"/>
  2. DirectWriteRolloverStrategy

    日志直接寫入由檔案模式表示的檔案。這兩個

    Strategy

    都是控制如何進行日志滾動的,平時大部分用

    DefaultRolloverStrategy

    就可以了。