- 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滾動政策
-
DefaultRolloverStrategy
預設滾動政策
常用參數:max,儲存日志檔案的最大個數,預設是7,大于此值會删除舊的日志檔案。
- <!--儲存日志檔案個數--><DefaultRolloverStrategy max="10"/>
-
DirectWriteRolloverStrategy
日志直接寫入由檔案模式表示的檔案。這兩個
都是控制如何進行日志滾動的,平時大部分用Strategy
就可以了。DefaultRolloverStrategy