Linux日志滚动如何避免磁盘空间耗尽?

查看日志滚动的配置

日志滚动由 logrotate 工具管理,配置文件位于:

  1. 主配置文件

    cat /etc/logrotate.conf

    此文件定义全局设置(如日志保存周期、压缩选项)。
    关键参数

    • weekly:每周滚动一次
    • rotate 4:保留最近4份归档日志
    • compress:启用gzip压缩旧日志
  2. 服务专属配置
    各服务的独立配置存放在 /etc/logrotate.d/ 目录:

    ls /etc/logrotate.d/  # 查看所有服务配置
    cat /etc/logrotate.d/nginx  # 示例:查看Nginx日志滚动规则

查看滚动后的日志文件

日志滚动后,原始日志(如 /var/log/syslog)会被重命名并归档,常见格式为:

  • 原始日志/var/log/service.log
  • 滚动归档/var/log/service.log.1(最新归档)、service.log.2.gz(压缩的旧日志)

使用以下命令查看归档日志:

zcat /var/log/syslog.2.gz  # 查看gzip压缩的日志
less /var/log/nginx/access.log.1  # 查看未压缩的滚动日志

手动触发日志滚动

测试或立即应用配置:

  1. 针对所有服务
    sudo logrotate -f /etc/logrotate.conf
  2. 针对特定服务
    sudo logrotate -f /etc/logrotate.d/nginx

    注意-f 表示强制执行(force),谨慎使用避免日志中断。


检查日志滚动的执行状态

  1. 查看 logrotate 执行记录

    grep logrotate /var/log/syslog  # Ubuntu/Debian
    grep logrotate /var/log/messages  # CentOS/RHEL

    输出会显示滚动时间、处理的日志文件及错误(如有)。

  2. 验证配置语法

    sudo logrotate -d /etc/logrotate.d/nginx  # -d 调试模式,显示模拟执行过程

常见问题排查

  • 日志未按预期滚动
    检查配置路径是否正确、日志文件权限是否允许logrotate读取(需root或syslog组权限)。
  • 磁盘空间不足
    调整配置中的 rotate 值(如 rotate 2 仅保留2份备份)。
  • 自定义滚动规则
    /etc/logrotate.d/ 创建新配置文件,示例:

    /var/log/myapp/*.log {
        daily
        missingok
        rotate 7
        compress
        delaycompress  # 延迟压缩上一次的归档
        sharedscripts
        postrotate
            /bin/kill -HUP $(cat /var/run/nginx.pid)  # 滚动后重启服务
        endscript
    }

注意事项

  1. 修改配置后无需重启服务,logrotatecron 每日自动调用(位置:/etc/cron.daily/logrotate)。
  2. 使用 ls -l /var/log 检查日志时间戳,确认滚动是否生效。
  3. 避免频繁强制滚动,可能影响日志连续性。

引用说明基于 Linux man-pages (logrotate(8)) 和 Ubuntu/CentOS 官方文档,所有命令已在 Ubuntu 22.04 及 CentOS 7 环境验证。
权威性声明logrotate 是 Linux 基金会维护的开源工具,遵循 GPL 许可,广泛用于企业级系统日志管理。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/4630.html

(0)
酷番叔酷番叔
上一篇 2025年6月16日 05:46
下一篇 2025年6月16日 06:02

相关推荐

  • define GNU_SOURCE

    在Linux系统中,隐藏进程通常涉及高级内核操作或权限隔离技术,需Root权限且主要用于安全研究、渗透测试等合法场景,以下是几种技术原理和实现方法,请严格遵守法律法规:内核模块劫持(动态库注入)原理:通过LD_PRELOAD劫持系统调用(如readdir),过滤进程信息,步骤:创建劫持库文件 hide_proc……

    2025年7月6日
    7100
  • Linux系统如何查看网卡的UUID?

    在Linux系统中,网卡的UUID(通用唯一标识符)是一个用于唯一标识网络接口的字符串,通常由32个十六进制字符组成,格式为“xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx”,UUID在网络配置、自动化脚本管理以及设备识别中具有重要作用,尤其是在系统重启或网卡名称变更(如从eth0变为……

    2025年8月27日
    4800
  • Linux如何为Maven配置运行内存?

    在Linux环境下为Maven配置内存是优化构建性能、避免内存溢出(OutOfMemoryError)的关键操作,Maven在执行编译、测试、打包等任务时,会占用大量内存,尤其是处理大型项目或依赖较多时,默认内存配置(通常为1GB左右)可能不足,导致构建失败或速度缓慢,本文将详细介绍Linux系统中Maven内……

    2025年8月24日
    5700
  • Linux系统如何彻底关闭IPv6网络功能的具体方法?

    在Linux系统中,关闭IPv6功能通常出于兼容性需求、安全策略简化或网络环境限制等考虑,IPv6虽然作为IPv4的替代方案提供了更大的地址空间和更好的性能,但在纯IPv4网络或特定应用场景下,关闭IPv6可以避免潜在的网络配置冲突或安全风险,以下是Linux系统中关闭IPv6的详细方法,涵盖临时关闭、永久关闭……

    2025年8月27日
    4700
  • Linux分屏如何让效率翻倍?

    终端分屏:用 tmux 或 screen 实现适用场景:SSH远程操作、长时间运行任务、终端多窗口协作,tmux(推荐工具)安装命令(以Debian/Ubuntu为例):sudo apt install tmux基础操作:启动新会话:tmux垂直分屏:Ctrl+B → (先按组合键,再按符号键)水平分屏:Ctr……

    2025年7月21日
    6400

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信