在logback日志记录中滚动不起作用

时间:2016-12-17 09:41:48

标签: java spring logging logback

我正在尝试在基于弹簧的项目中创建记录器策略。

我面临的问题与滚动政策有关。 logfile.log 已创建且工作正常,但未创建滚动文件 rollingfile.log。%d {yyyy-MM-dd} .log

注意:在下面的记录器中,我希望创建一个滚动策略,在 rollingfile.log超过10 Mb 时创建新文件。所以我可以备份日志而无需一个巨大的记录器文件。有没有办法做到这一点?

以下是我的 logback.xml

<?xml version="1.0" encoding="UTF-8"?>
    <configuration debug="true" scan="true" scanPeriod="30 seconds">
        <property name="LOG_PATH" value="D:/coinLogs" />
        <property name="LOG_ARCHIVE" value="${LOG_PATH}/archive" />

        <appender name="Console-Appender" class="ch.qos.logback.core.ConsoleAppender">
            <layout>
                <pattern>[%d{yyyy-MM-dd HH:mm:ss}] - [%X{requestId}] - %p %c -- %m%n
                </pattern>
            </layout>
        </appender>

        <appender name="File-Appender" class="ch.qos.logback.core.FileAppender">
            <file>${LOG_PATH}/logfile.log</file>
            <encoder>
                <pattern>[%d{yyyy-MM-dd HH:mm:ss}] - [%X{requestId}] - %p %c -- %m%n
                </pattern>
                <outputPatternAsHeader>true</outputPatternAsHeader>
            </encoder>
        </appender>

        <appender name="RollingFile-Appender"
            class="ch.qos.logback.core.rolling.RollingFileAppender">
            <file>${LOG_PATH}/rollingfile.log</file>
            <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
                <fileNamePattern>${LOG_ARCHIVE}/rollingfile.log%d{yyyy-MM-dd}.log
                </fileNamePattern>
                <maxHistory>30</maxHistory>
                <totalSizeCap>10MB</totalSizeCap>
            </rollingPolicy>
            <encoder>
                <pattern>%msg%n</pattern>
            </encoder>
        </appender>

        <appender name="Async-Appender" class="ch.qos.logback.classic.AsyncAppender">
            <appender-ref ref="RollingFile-Appender" />
        </appender>

        <logger name="coinPay.logbackxml" level="info" additivity="false">
            <appender-ref ref="Console-Appender" />
            <appender-ref ref="File-Appender" />
            <appender-ref ref="Async-Appender" />
        </logger>

        <!-- To remove extra hibernate logs -->
        <logger name="org.hibernate">
            <level value="info" />
        </logger>

        <root>
            <appender-ref ref="Console-Appender" />
            <appender-ref ref="File-Appender" />
        </root>

    </configuration>

任何帮助将不胜感激。提前谢谢你:D

1 个答案:

答案 0 :(得分:1)

我认为你应该添加配置的根元素,包装你的RollingFile-Appender的Async-Appender appender。 否则,它可能不会被logback视为启用:

    <root>
        <appender-ref ref="Console-Appender" />
        <appender-ref ref="File-Appender" />
        <appender-ref ref="Async-Appender" />
    </root>