最近在学习日志文件的使用配置,发现了几个坑点,记录
1、按日期滚动,每日生成一个新文件,logback 版本 1.1.11,
滚动方式 TimeBasedRollingPolicy
这种配置如果fileNamePattern属性使用变量引用时不生效(如:${LOG_HOME}-%d{yyyy-MM-dd}.log),必须使用绝对路径,据说这是一个bug,亲测也确实无效
<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="60 seconds" debug="false">
<property name="APP_NAME" value="cloud"/>
<property name="LOG_HOME" value="/opt/logs/${APP_NAME}"/>
<property name="PATTERN" value="[%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] [%c{12}:%L] %msg%n"/>
<contextName>${APP_NAME}</contextName>
<appender name="console" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>${PATTERN}</pattern>
</encoder>
</appender>
<appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender">
<!--<file>${LOG_HOME}.log</file>-->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>/opt/logs/${APP_NAME}-%d{yyyy-MM-dd}.log</fileNamePattern>
<!-- 日志文件最大尺寸 -->
<!--<maxFileSize>10MB</maxFileSize>-->
<!--日志文件保留天数-->
<maxHistory>30</maxHistory>
</rollingPolicy>
<encoder>
<pattern>${PATTERN}</pattern>
</encoder>
</appender>
<appender name="async_log" class="ch.qos.logback.classic.AsyncAppender">
<appender-ref ref="file"/>
</appender>
<springProfile name="test,dev">
<root level="info">
<appender-ref ref="console"/>
<appender-ref ref="async_log"/>
</root>
<logger name="com.lt.cloud" level="debug" additivity="false">
<appender-ref ref="console"/>
<appender-ref ref="async_log"/>
</logger>
</springProfile>
<springProfile name="prod,prod1,prod2">
<root level="info">
<appender-ref ref="console"/>
<appender-ref ref="async_log"/>
</root>
<logger name="com.lt.cloud" level="info" additivity="false">
<appender-ref ref="console"/>
<appender-ref ref="async_log"/>
</logger>
</springProfile>
</configuration>
这个版本使用下面的滚动方式:SizeAndTimeBasedRollingPolicy 也能生效,日志路径可以用变量
<appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender">
<!--<file>${LOG_HOME}.log</file>-->
<rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
<fileNamePattern>${LOG_HOME}.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<!-- 日志文件最大尺寸 -->
<maxFileSize>10MB</maxFileSize>
<!--日志文件保留天数-->
<maxHistory>10</maxHistory>
</rollingPolicy>
<encoder>
<pattern>${PATTERN}</pattern>
</encoder>
</appender>
换了更高的版本:1.2.3 则使用TimeBasedRollingPolicy可以不用绝对路径
<appender name="file" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${LOG_HOME}.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>${LOG_HOME}.log.%d{yyyy-MM-dd}</fileNamePattern>
</rollingPolicy>
<encoder>
<pattern>${PATTERN}</pattern>
</encoder>
</appender>