当前位置: 首页 > news >正文

Linux命令-logrotate(自动轮转、压缩、删除和邮件发送日志文件)

🧭说明

logrotate是Linux系统中用于自动轮转、压缩、删除和邮件发送日志文件的工具,能有效防止日志文件占用过多磁盘空间。下面这个表格汇总了它的核心配置参数和用法。

类别配置参数/命令功能说明
轮转周期daily,weekly,monthly,yearly按时间周期触发轮转
size 10M,size 100k当日志文件达到指定大小时触发轮转
文件处理rotate 5保留5个轮转后的历史日志文件
compress,delaycompress压缩历史日志(delaycompress延迟压缩最新一个)
missingok,notifempty日志缺失不报错;空文件不轮转
create 644 root root轮转后创建新日志文件并设置权限
copytruncate复制原日志后截断,适用于无法重启的进程
执行控制prerotate/endscript,postrotate/endscript在轮转前/后执行自定义脚本
手动执行logrotate -f /etc/logrotate.d/nginx强制轮转指定配置
logrotate -d /etc/logrotate.d/nginx调试模式,验证配置但不实际执行
logrotate -v /etc/logrotate.conf详细模式,显示处理过程

📁 配置文件与位置

logrotate的配置非常灵活,通常不需要修改主配置文件。

  • 主配置文件/etc/logrotate.conf。这里定义了全局默认设置
  • 自定义配置目录/etc/logrotate.d/。这是最常使用的目录,每个应用程序(如Nginx、PHP)或服务都可以在这里拥有自己的配置文件,它们会覆盖全局默认值。系统管理员通常将分散的转储信息集中到主配置文件管理。

💡 实际应用示例

掌握理论后,来看看如何为常见服务配置logrotate。

  • Nginx日志轮转:在/etc/logrotate.d/nginx文件中配置以下内容,可以实现日志的每日轮转、压缩,并通知Nginx进程重新打开日志文件。
    /var/log/nginx/*.log{daily# 每天轮转rotate7# 保留7天的备份missingok# 日志丢失不报错notifempty# 空文件不轮转compress# 压缩旧日志dateext# 使用日期作为备份文件的后缀sharedscripts postrotate# 通知Nginx重新打开日志文件if[-f /run/nginx.pid];thenkill-USR1`cat/run/nginx.pid`fiendscript}
  • 系统日志文件:对于由rsyslog管理的系统日志(如/var/log/syslog),配置中通常包含postrotate脚本来重启rsyslogd服务。
    /var/log/syslog{rotate7daily missingok notifempty delaycompress compress postrotate /usr/bin/killall -HUP rsyslogd endscript}

🔧 手动执行与调试

虽然logrotate通过cron任务定期自动运行,但在修改配置后,手动执行和调试是确保配置正确的关键步骤。

  • 强制轮转:使用-f--force选项可以立即触发轮转,即使未达到条件。
    logrotate-f /etc/logrotate.d/your-app
  • 调试配置强烈推荐在使用-f之前,先使用-d--debug选项进行调试。此模式会模拟运行并显示详细过程,但不会实际修改任何日志文件,帮助发现配置错误。
    logrotate-d /etc/logrotate.d/your-app

✅ 关键使用要点

  • 理解postrotate的作用:对于许多服务(如Nginx、Apache),轮转后需要使用postrotate脚本通过信号通知服务重新打开日志文件。否则服务可能继续向已轮转(重命名)的旧文件写入日志。
  • 优先使用调试模式:在将新配置投入生产环境前,始终使用logrotate -d进行测试,这可以避免因配置错误导致日志丢失。
  • 注意权限问题:如果日志文件由非root用户创建,可能需要在配置中使用su指令指定正确的用户和组,以确保logrotate有权限进行轮转操作。
http://www.jsqmd.com/news/334725/

相关文章:

  • 当数组已经排好序,你还在从头遍历?——聊聊 H 指数 II 背后的“算法直觉”
  • ClickHouse:为大数据架构添砖加瓦
  • <span class=“js_title_inner“>《在细雨中呼喊》:当你混到连个找你的人都没有,没人找你吃饭,没人喊你聚会,真该庆祝一下:不是人缘变差了,而是远离了低质量的热闹。</span>
  • 从腾讯离开后,我的“近屿智能”转型记
  • 【游戏推荐】装机模拟器2 全DLC 送修改器(PCBuildingSimulator2)免安装中文版
  • 深度剖析:金融AI风险预警机制的底层架构逻辑——AI应用架构师视角
  • 【踩坑实录】Windows ICS 共享网络下,国产化盒子 SSH 连接异常的完整分析
  • 【游戏推荐】冰汽时代2 全DLC 送修改器(Frostpunk 2)免安装中文版
  • 创建线程 解决跨线程访问UI页面问题
  • Halo与cpolar打造超强组合,让个人博客随时随地能访问
  • 【计算机毕业设计案例】基于SSM的中介房屋管理系统的设计与实现基于ssm的房屋中介公司网站的设计与实现(程序+文档+讲解+定制)
  • 创建任务 处理异步任务顺序问题
  • 学术 PPT 还在 “文字堆 + 乱图表”?虎贲等考 AI 一键生成评审级汇报,答辩 / 课题宣讲直接出彩
  • 【游戏推荐】酒店:度假村模拟(Hotel A Resort Simulator)免安装中文版
  • STM32步进电机4轴控制源码,相对,绝对,回原点,梯形加减 STM32步进电机4轴控制源码...
  • <span class=“js_title_inner“>ITIL4发布计划:90%的运维团队都在“假交付“?</span>
  • 513. 找树左下角的值-day14
  • 问卷设计还在 “凭感觉凑题”?虎贲等考 AI 让 “无效问卷” 变 “数据金矿”,信效度直接达标
  • SSM毕设项目推荐-基于ssm的航班订票系统的设计与实现提供机票预订,飞机票查询时刻表【附源码+文档,调试定制服务】
  • <span class=“js_title_inner“>单菌基因组数据分析 (往期内容) 合集 2026.1.20</span>
  • AT_arc050_b
  • C#编写西门子S7系列PLC上位机通信,ⅤS2017编写,涵盖读写寄存器,中间继电器,外部IO...
  • 19.行为型 - 策略模式(Strategy Pattern)
  • 科研绘图被审稿人连环吐槽?虎贲等考 AI:10 分钟生成期刊级合规图表
  • 该模型为光伏逆变器低电压穿越仿真模型采用boost加NPc Simulink|光伏并网逆变器低...
  • 降重 + 去 AIGC 双 buff 拉满!虎贲等考 AI:让论文原创性无可挑剔
  • 基于领航者ZYNQ7020实现的手写数字识别工程 ov7725摄像头采集数据,通过HDMI接口...
  • <span class=“js_title_inner“>第148篇:卷积神经网络算法识别复杂验证码/图像/人脸识别的原理讲解</span>
  • 【2025年RE SCI1区TOP】改进鲸鱼优化算法IWOA+多尺度聚类集成与相似性匹配的综合风电预测系统附Matlab代码
  • SSM毕设选题推荐:基于SSM框架的二手房中介管理系统基于ssm的房屋中介公司网站的设计与实现【附源码、mysql、文档、调试+代码讲解+全bao等】