logback 中SizeAndTimeBasedRollingPolicy 的maxFileSize不生效的问题

当我将其设置成

<maxFileSize>1KB</maxFileSize>

的时候死活不生效。就是不给我按照大小分割。
将logback的日志信息打印如下:

Archive files will be limited to [1 KB] each.

明明是生效了啊,怎么回事呢?
原来,是这个1KB设置的太小了,logback"来不及切割",因为我其实就想测一下这个按照大小分割的功能,所以设置了1KB。

按照前人经验,得设置成10MB,才能看出来。
因此我直接写了个循环,把logger.info(“坑啊。。。”)循环了若干遍。

终于,出现了按照大小分割的文件。

在这里插入图片描述
原来就是来不及切分的原因,下面还有几个51MB的也来不及切分。

原因就是这样了。

下面提供一下我的logback.xml配置参考一下

<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="60 seconds" debug="false">
    <!--定义参数常量-->
    <!-- 日志级别从低到高分为TRACE < DEBUG < INFO < WARN < ERROR < FATAL,如果设置为WARN,则低于WARN的信息都不会输出 -->
    <property name="log.level" value="debug"/>
    <!--文件保留时间-->
    <property name="log.maxHistory" value="2"/>
    <!--单个文件最大大小-->
    <property name="log.maxFileSize" value="10MB"/>
    <!--所有日志最多占有多大硬盘-->
    <property name="log.totalSizeCap" value="20GB"/>
    <!--日志根目录-->
    <property name="log.filePath" value="/Users/pythonbug/"/>
    <!--日志的输出格式-->
    <property name="log.pattern" value="%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n"/>
    <!--控制台输出-->
    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <!--转行成字符串,输出-->
        <encoder>
            <pattern>${log.pattern}</pattern>
        </encoder>
    </appender>
    <!--文件输出-->
    <appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!--文件路径-->
        <file>${log.filePath}/debug.log</file>
        <!--滚动策略-->
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <!--归档文件名称-->
            <fileNamePattern>${log.filePath}/debug/debug.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
            <!--文件最大保存历史数量-->
            <maxHistory>${log.maxHistory}</maxHistory>
            <!--单个日志最大容量 至少10MB才能看得出来-->
            <maxFileSize>${log.maxFileSize}</maxFileSize>
            <!--所有日志最多占多大容量-->
            <totalSizeCap>${log.totalSizeCap}</totalSizeCap>
        </rollingPolicy>

        <encoder>
            <pattern>${log.pattern}</pattern>
        </encoder>
        <!--暂时不区分目录存日志-->
<!--        <filter class="ch.qos.logback.classic.filter.LevelFilter">-->
<!--            <level>DEBUG</level>-->
<!--            <onMatch>ACCEPT</onMatch>-->
<!--            <onMismatch>DENY</onMismatch>-->
<!--        </filter>-->
    </appender>

    <root level="${log.level}">
        <appender-ref ref="file" />
        <appender-ref ref="console" />
    </root>
</configuration>
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
你好!对于logback.xml配置在Spring Boot不生效问题,有几个可能的原因和解决方法: 1. 确认logback.xml位置:确保logback.xml文件位于正确的位置。默认情况下,它应该位于src/main/resources目录下。 2. 检查日志级别:在logback.xml,确保你设置了适当的日志级别。例如,如果你只想看到ERROR级别的日志信息,那么你的配置应该类似于: ```xml <root level="ERROR"> <appender-ref ref="CONSOLE"/> </root> ``` 3. 检查logger配置:确保你正确配置了logger节点。例如,如果你想为特定的包设置日志级别,你可以添加如下配置: ```xml <logger name="com.example.package" level="DEBUG"/> ``` 确保包名和级别都正确,并且没有其他的logger节点覆盖了它。 4. 检查appender配置:确保你正确配置了appender节点。例如,如果你想将日志输出到控制台,你可以添加如下配置: ```xml <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"> <encoder> <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern> </encoder> </appender> ``` 确保你选择了适合你的需求的appender类型,并且配置项正确。 5. 清除缓存并重新启动:有时候,logback.xml的更改可能需要清除缓存并重新启动应用程序才能生效。尝试清除你的构建目录,然后重新构建和启动应用程序。 希望这些解决方法能帮助你解决问题!如果还有其他问题,请随时提问。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值