应用系统日志分割及日志清理方案

本文介绍了如何扩展log4j实现日志按天和文件大小进行分割,以及如何配置自动压缩和清理日志。通过自定义DailySizeRollingFileAppender,设置日志目录、大小限制、保留天数,配合定时任务脚本zip_clear_log.sh,实现了30天前日志清理和7天前日志压缩。无需服务重启即可切换日志等级。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


前言

  应用日志是用来排查问题的基础,由于所解除的项目上,日志未做分割,日积月累后日志文件逐渐变的很大,占用存储不说,对于后续出现问题进行日志排查时,难以打开文件及查找。
  而现有的log4j-1.2.15版本仅支持按天切割或者按文件大小切割,没有同时支持按天以及文件大小的切割方式(应该是1的版本都不支持),这使得当一天的日志量过大时,查看起来还是比较困难。
  本文主要就是针对基于log4j进行扩展的增强日志分割方式:按天以及按文件大小的方式进行日志切割,并实现日志的定期压缩及删除,切换日志级别不用重启服务。


一、实现功能描述

  1. 支持设置日志文件生成的目录;
  2. 支持设置单个日志文件的大小;
  3. 支持设置每天日志文件的个数(超过则覆盖当天最早的日志);
  4. 支持设置日志输出的格式按照自定义方式设置;
  5. 支持设置日志输出等级,且不用重启服务;
  6. 支持每天定时设置清理30天之前的日志、压缩7天之前的日志。

二、解决方案

说明:本方案是基于log4j-1.2.25.jar、spring-web-1.2.8.jar包实现的,其他版本可参考。

1.自定义DailySizeRollingFileAppender处理类继承FileAppender

  新增DailySizeRollingFileAppender.java文件,代码如下

package org.apache.log4j;

import org.apache.log4j.helpers.CountingQuietWriter;
import org.apache.log4j.helpers.LogLog;
import org.apache.log4j.helpers.OptionConverter;
import org.apache.log4j.spi.LoggingEvent;

import java.io.File;
import java.io.IOException;
import java.io.InterruptedIOException;
import java.io.Writer;
import java.text.SimpleDateFormat;
import java.util.Date;

/**
 * 自定义日志分割处理类
 */
public class DailySizeRollingFileAppender extends FileAppender {
   
	protected long maxFileSize = 10485760L;
	protected int maxBackupIndex = 1;
	private long nextRollover = 0L;
	private static SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd");

	public DailySizeRollingFileAppender() {
   }

	public DailySizeRollingFileAppender(Layout layout, String filename, boolean append) throws IOException {
   
		super(layout, filename, append);
	}
	
	public DailySizeRollingFileAppender(Layout layout, String filename) throws IOException {
   
		super(layout, filename);
	}

	public int getMaxBackupIndex() {
   
		return this.maxBackupIndex;
	}

	public long getMaximumFileSize() {
   
		return this.maxFileSize;
	}

	public void rollOver() 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值