logrotate日志切割

一、什么是logrotate

logrotate是Linux系统中一个开源日志管理工具 ,用于自动化管理日志文件。它通过预设规则实现日志文件的切割、压缩、备份和删除,有效防止日志文件无限增长占用磁盘空间。Linux系统下大多自带logrotate服务,无需手动安装(本文档基于CentOS7)。

二、核心功能特性

  1. 切割机制:支持按时间(daily/weekly/monthly)或文件大小(size)触发轮转
  2. 压缩存储:使用gzip标准压缩算法减少存储空间占用
  3. 自动清理:按配置保留指定数量的历史日志文件
  4. 安全操作:采用inode机制处理日志文件,避免影响应用程序

三、配置文件结构

/etc/logrotate.conf 核心配置文件

/etc/logrotate.d/ 日志切割任务目录

四、关键配置参数详解

参数 说明
daily / weekly / monthly 按日期轮转,天/周/月
size 100M 按文件大小轮转
rotate N 旧日志的最大保存数量
compress 压缩旧日志文件
delaycompress 延迟压缩(下一次轮转时压缩)
missingok 日志文件不存在时跳过
notifempty 日志为空时不轮转
create 0640 root root 创建新日志文件的权限
copytruncate 使用拷贝截断模式,复制日志后清空原文件

注意:logrotate按天切割日志并不是固定0点整执行,有5~50分钟的随机延迟,详细可查看/etc/anacrontab文件;可通过 grep 'logrotate' /var/log/cron 命令查看logrotate服务的启动时间

五、日志切割配置示例:

示例1:

/etc/logrotate.d/celery

/data/demo/logs/celery*.log {

create 0640 root root

daily

rotate 30

missingok

notifempty

compress

copytruncate

}

示例2:

/etc/logrotate.d/nginx

/etc/nginx/logs/*.log {

create 0640 nginx root

daily

rotate 15

missingok

notifempty

compress

sharedscripts

postrotate

/bin/kill -USR1 `cat /run/nginx.pid 2>/dev/null` 2>/dev/null || true

endscript

}

配置解析(示例2):

/etc/nginx/logs/*.log { # 要切割的日志文件,可以使用*匹配多个文件

create 0640 nginx root # 新日志文件的权限

daily # 按天切割

rotate 15 # 旧日志的最大保存数量

missingok # 跳过不存在的日志文件

notifempty # 跳过空的日志文件

compress # 压缩旧日志

sharedscripts # 所有匹配的日志切割完毕后执行一次脚本

postrotate # 执行脚本开始

/bin/kill -USR1 `cat /run/nginx.pid 2>/dev/null` 2>/dev/null || true # 通知nginx重新打开日志文件

endscript # 执行脚本结束

}

测试配置文件的正确性:

logrotate -d /etc/logrotate.d/celery

强制触发一次切割日志:

logrotate -f /etc/logrotate.d/celery

相关推荐
张小姐的猫2 分钟前
【Linux】多线程 —— 线程互斥
linux·运维·服务器·c++
CodeMartain25 分钟前
Dify Windows 原生部署(无 Docker、纯本地)
运维·docker·容器
xxx1x1x30 分钟前
极客向:DLL/运行库故障的底层逻辑与自动化修复方案
运维·自动化·dll文件·dll·dll修复·dll缺失·dll一键修复
YuanDaima204833 分钟前
Linux 进阶运维与 AI 环境实战:进程管理、网络排错与 GPU 监控
linux·运维·服务器·网络·人工智能
lolo大魔王2 小时前
Linux 数据文件处理实战:排序、搜索、压缩、归档一站式详解
linux·运维·服务器
llrraa20102 小时前
配置docker国内镜像源
运维·docker·容器
starvapour2 小时前
Ubuntu切换到Fcitx5中文输入法
linux·运维·ubuntu
189228048612 小时前
NY382固态MT29F32T08GSLBHL8-24QM:B
大数据·服务器·人工智能·科技·缓存
xhbh6663 小时前
网关端口映射和路由器端口转发有什么区别?配置要点全解析
运维·服务器·网络·智能路由器·端口映射·映射·无痕网关
STDD3 小时前
Soulmask《灵魂面具》 专用服务器搭建教程
运维·服务器·github