logback 之 创建 RollingFileAppender

最近有需求要将context信息写入文件,以备后续数据分析。本想直接同步写入文件了事,但是logback针对日志的输出性能尤佳,且为异步写入。既然logback封装如此完美,何不直接使用?

 

动态创建Logger及其appender。代码如下:

 

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import ch.qos.logback.classic.Level;
import ch.qos.logback.classic.LoggerContext;
import ch.qos.logback.classic.encoder.PatternLayoutEncoder;
import ch.qos.logback.classic.spi.ILoggingEvent;
import ch.qos.logback.core.rolling.RollingFileAppender;
import ch.qos.logback.core.rolling.TimeBasedRollingPolicy;
 
        Logger logger = LoggerFactory.getLogger(loggerName);
        LoggerContext loggerContext = (LoggerContext) LoggerFactory.getILoggerFactory();
        
        ch.qos.logback.classic.Logger newLogger = (ch.qos.logback.classic.Logger)logger;
        //Remove all previously added appenders from this logger instance.
        newLogger.detachAndStopAllAppenders();
        
        //define appender
        RollingFileAppender<ILoggingEvent> appender = new RollingFileAppender<ILoggingEvent>();
        
        //policy
        TimeBasedRollingPolicy<ILoggingEvent> policy = new TimeBasedRollingPolicy<ILoggingEvent>();
        policy.setContext(loggerContext);
        policy.setMaxHistory(5);
        policy.setFileNamePattern("/home/lionbule/%d{yyyy-MM-dd}.log");
        policy.setParent(appender);
        policy.start();
        
        //encoder
        PatternLayoutEncoder encoder = new PatternLayoutEncoder();
        encoder.setContext(loggerContext);
        encoder.setPattern("%message%n");
        encoder.start();
        
        //start appender
        appender.setRollingPolicy(policy);
        appender.setContext(loggerContext);
        appender.setEncoder(encoder);
        appender.setPrudent(true); //support that multiple JVMs can safely write to the same file.
        appender.start();
        
        newLogger.addAppender(appender);
        
        //setup level
        newLogger.setLevel(Level.WARN);
        //remove the appenders that inherited 'ROOT'.
        newLogger.setAdditive(false);

上述代码为草稿,具体使用细节,则根据自己的需求调整。 

 

要点总结:

1. 成功创建appender的关键在于,要实例化一个appender,然后set policy/encoder/&others...

    最后再start appender。

    并且在创建policy时,一定要记住set当前实例化的appender。

    具体步骤看上述demo。

 

 

 

### 配置 Logback 按照日期创建日志文件夹 为了使Logback能够根据日期来创建新的日志文件并存储到相应的文件夹中,需要正确设置`logback-spring.xml`或`logback.xml`中的配置项。以下是具体的配置方法: #### 使用 `SizeAndTimeBasedRollingPolicy` 通过采用`SizeAndTimeBasedRollingPolicy`策略,不仅可以基于时间滚动日志文件,还可以控制旧的日志文件大小以及自动清理过期的日志数据。 ```xml <configuration> <!-- 定义日志输出格式 --> <property name="LOG_PATH" value="logs"/> <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> <file>${LOG_PATH}/application.log</file> <encoder> <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern> </encoder> <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy"> <!-- 日志文件名模式 --> <fileNamePattern>${LOG_PATH}/%d{yyyy-MM-dd}.%i.log.zip</fileNamePattern> <!-- 单个日志文件最大尺寸 --> <maxFileSize>10MB</maxFileSize> <!-- 总保留天数 --> <maxHistory>30</maxHistory> <!-- 启动时压缩历史日志 --> <cleanHistoricCompressedFiles>true</cleanHistoricCompressedFiles> </rollingPolicy> <!-- 设置触发条件为当日志达到指定大小时进行分割 --> <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy"> <maxFileSize>10MB</maxFileSize> </triggeringPolicy> </appender> <root level="debug"> <appender-ref ref="FILE" /> </root> </configuration> ``` 上述配置实现了按每天生成一个新的日志文件,并将其存放在`${LOG_PATH}`变量所指向的位置(默认为当前工作目录下的`logs`子目录)。当某一天的日志量超过设定的最大值(此处设为10 MB),则会立即创建新文件继续记录后续的信息;而之前的老文件会被打包成`.zip`形式保存下来[^2]。 此外,在应用启动之初便会检查是否存在超出规定期限的历史归档文件,并对其进行清除操作以释放磁盘空间[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值