Linux日志怎么切割_Linux日志通过cron和logrotate联合实现精准切割的教程

17次阅读

logrotate 是 linux 日志管理 工具 ,通过 cron 定时调用实现日志自动切割、压缩与清理;以nginx 为例,在 /etc/logrotate.d/nginx 中配置 d aily、rotate 7、compress 等参数,结合 postrotate 脚本通知服务重载,确保日志高效轮转,避免磁盘溢出。

Linux 日志怎么切割_Linux 日志通过 cron 和 logrotate 联合实现精准切割的教程

linux 系统 中日志文件如果长期不处理,会不断增大,影响系统性能和排查问题的效率。为了解决这个问题,通常采用 cronlogrotate 联合的方式来实现日志的自动切割、归档与清理。这套机制稳定可靠,是生产环境中的标准做法。

logrotate 是什么?

logrotate 是 Linux 系统自带的日志管理 工具,专门用于自动切割日志文件。它可以根据文件大小、时间周期(如每天、每周)等条件触发切割,并支持压缩、删除旧日志、发送通知等操作。

配置文件 一般位于:/etc/logrotate.conf,而具体服务的日志规则通常放在 /etc/logrotate.d/ 目录下。

如何配置 logrotate 实现日志切割?

以 Nginx 的访问日志为例,演示如何配置精准切割:

创建 配置文件/etc/logrotate.d/nginx

内容如下:

<font face="monospace"> /var/log/nginx/*.log {daily     missingok     rotate 7     compress     delaycompress     notifempty     create 0640 www-data adm     sharedscripts     postrotate         [-f /var/run/nginx.pid] && kill -USR1 `cat /var/run/nginx.pid`     endscript } </font>

参数说明:

  • daily:每天切割一次
  • missingok:日志文件不存在时不报错
  • rotate 7:保留最近 7 个备份(即 7 天)
  • compress:启用压缩(.gz 格式)
  • delaycompress:延迟压缩,最新一份日志不立即压缩
  • notifempty:日志为空时不切割
  • create 0640:切割后创建新日志文件,权限和所属用户 / 组设置
  • sharedscripts:所有日志只执行一次 postrotate 脚本
  • postrotate/endscript:脚本块,在切割后执行,用于通知服务重新打开日志文件

cron 如何触发 logrotate?

logrotate 本身不主动运行,它依赖 cron 定时任务来调用。大多数 Linux 发行版默认已配置好 cron 来每天执行 logrotate。

查看定时任务:

Linux 日志怎么切割_Linux 日志通过 cron 和 logrotate 联合实现精准切割的教程

AI 卡通生成器

免费在线 AI 卡通图片生成器 | 一键将图片或文本转换成精美卡通形象

Linux 日志怎么切割_Linux 日志通过 cron 和 logrotate 联合实现精准切割的教程 51

查看详情 Linux 日志怎么切割_Linux 日志通过 cron 和 logrotate 联合实现精准切割的教程

cat /etc/cron.daily/logrotate

该脚本内容通常是:

<font face="monospace"> #!/bin/sh /usr/sbin/logrotate -s /var/lib/logrotate/logrotate.status /etc/logrotate.conf EXITVALUE=$? if [$EXITVALUE != 0]; then     /usr/bin/logger -t logrotate "Alert exited with code $EXITVALUE" fi exit 0 </font>

这表示每天通过 cron 执行一次 logrotate,检查所有配置是否需要触发切割。

如果你想改为每小时切割一次,可以将脚本移到 /etc/cron.hourly/ 并修改配置使用 hourly 指令,但注意需手动创建状态文件并确保权限正确。

测试与调试技巧

在正式应用前,建议先测试配置是否正确:

  • 语法检查:logrotate -d /etc/logrotate.d/nginx(debug 模式,不实际执行)
  • 强制执行一次:logrotate -f /etc/logrotate.d/nginx
  • 查看状态记录:cat /var/lib/logrotate/logrotate.status,确认最后处理时间

观察日志切割后,原文件是否重命名为 access.log.1.gz,新文件是否生成,服务是否正常写入新日志。

基本上就这些。只要配置好 logrotate 规则,并确保 cron 正常运行,就能实现日志的 自动化 管理,避免磁盘被日志撑满的问题。关键是理解每个指令的作用,并根据实际需求调整周期和保留策略。

站长
版权声明:本站原创文章,由 站长 2025-11-11发表,共计1773字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
1a44ec70fbfb7ca70432d56d3e5ef742
text=ZqhQzanResources