博客 / 詳情

返回

log4j2定期刪除日誌文

在Log4j 2中,你可以使用 Delete策略來定期刪除日誌文件。以下是一個配置示例,演示如何在Log4j 2中配置定期刪除日誌文件:

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="WARN">

<Appenders>
    <RollingFile name="RollingFile" fileName="logs/app.log"
                 filePattern="logs/app-%d{MM-dd-yyyy}-%i.log.gz">
        <Delete basePath="logs" maxDepth="1">
            <IfFileName glob="app-*.log.gz" />
            <IfLastModified age="7d" />
        </Delete>
        <PatternLayout pattern="%d %-5p [%t] %c: %m%n" />
        <Policies>
            <TimeBasedTriggeringPolicy />
            <SizeBasedTriggeringPolicy size="10 MB" />
        </Policies>
        <DefaultRolloverStrategy max="10" />
    </RollingFile>
</Appenders>
<Loggers>
    <Root level="info">
        <AppenderRef ref="RollingFile" />
    </Root>
</Loggers>

</Configuration>

在上面的示例中,<Delete>元素用於配置定期刪除日誌文件。具體來説,以下是配置的要點:

basePath="logs":指定日誌文件的基本路徑。
<IfFileName glob="app-*.log.gz" />:指定要刪除的文件的文件名匹配模式。
<IfLastModified age="7d" />:指定文件的最後修改時間必須超過7天,才會被刪除。
注意,上述配置會刪除7天前的所有 app-*.log.gz日誌文件。你可以根據需求調整 <IfFileName>和 <IfLastModified>的參數以及其他配置。配置中的其他部分(如 <PatternLayout>、<Policies>和 <DefaultRolloverStrategy>)用於日誌文件滾動和策略。

user avatar beiyinglunkuo 頭像 u_16213664 頭像
2 位用戶收藏了這個故事!

發佈 評論

Some HTML is okay.