繁体   English   中英

log4j2 滚动文件附加程序中的文件名问题

[英]Issue with filename in log4j2 rolling file appender

我有以下 log4j2.xml 配置。 我有一个基于时间和大小的触发策略。 由于首先违反了大小限制 (10 MB),因此日志文件会翻转,并且在创建新文件时,它会将错误的日期附加到文件名。 我想要的是:

  • 当文件大小达到 10 MB 时翻转(所有文件的总大小不应超过 1500 乘以 10 MB)
  • 每15天滚动一次

文件名应为 abc.log、abc__2021-04-09__1.log、abc__2021-04-09__2.log。 基本上它应该附加当前日期。

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="INFO">
    <Appenders>
        <RollingFile name="RollingFileAppender" fileName="/var/log/abc/abc.log"
                     filePattern="/var/log/abc/abc__%d{yyyy-MM-dd}__%i.log" immediateFlush="false" append="true">
            <JsonLayout complete="true" compact="true" eventEol="true">
                <KeyValuePair key="timestamp" value="$${date:yyyy-MM-dd'T'HH:mm:ss.SSSZ}"/>
            </JsonLayout>
            <Policies>
                <TimeBasedTriggeringPolicy interval="15"/>
                <SizeBasedTriggeringPolicy size="10 MB"/>
            </Policies>
            <DefaultRolloverStrategy max="1500"/>
        </RollingFile>
    </Appenders>
 
    <Loggers>
        <Root level="info" includeLocation="false">
            <AppenderRef ref="RollingFileAppender"/>
        </Root>
    </Loggers>
</Configuration>

请让我知道我的代码哪里错了。 提前致谢。

新编辑

要求 - 1) 或 2) 中的任何一个发生较早:

  1. 当所有文件的总大小超过 1500 倍时 10 MB ~ 15 GB(一个文件的大小为 10 MB)
  2. 自服务开始后每 15 天

如果 1) 发生早于 2),它应该根据记录的速度一一刷新文件的现有内容,并写入文件名附加当前日期的文件(而不是启动服务的日期)。

如果 2) 发生早于 1),它应该删除所有现有文件并开始写入文件名附加当前日期的文件(而不是启动服务的日期)。

请帮助正确配置。

您可以使用 cron 每 15 天翻转一次

<CronTriggeringPolicy schedule="30 15 */15 * * "/> 

RollingFileAppender 使用文件模式中的日期模式来确定翻转的频率。 由于粒度为 1 天,这通常表明它应该每天翻转。 然后,您添加了 interval=15,因此已将其指示为每 15 天翻转一次。 滚动文件的日期将始终是最后一次基于时间的滚动的日期。 当您添加基于大小的触发策略时,您表示在该时间 window 内可能会有进一步的翻转。 您应该将文件视为一个基于时间的翻转,它会被基于大小的翻转周期性地中断,因此所有这些都会增加索引上的计数器。

max 参数表示您希望在 window 的 15 天内允许 1500 个文件,而不是总共 1500 个文件的限制。

如果您希望文件名中的日期每天更改,那么您需要使用 1 的间隔。

如果要将总文件数限制为 1500,则需要在翻转策略中添加删除操作。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM