Linux logrotate 高级配置实践

2次阅读

logrotate没生效主因是未被cron触发;missingok与create共用易致日志丢失;size与daily为或关系,需minage折中;/etc/logrotate.d/文件按字典序加载,调试用-d查看实际配置。

Linux logrotate 高级配置实践

logrotate 没生效?先确认它是否真在运行

很多配置写完没效果,不是语法错,而是 logrotate 根本没被触发。它默认不常驻,靠 cron 定时调用,常见路径是 /etc/cron.daily/logrotate。如果系统没启用 daily cron(比如某些容器或精简版系统),配置再对也白搭。

实操建议:

  • 手动执行一次验证:sudo logrotate -d /etc/logrotate.conf-d 是 debug 模式,不实际轮转,只打印行为)
  • 检查 cron 是否启用:systemctl list-timers | grep logrotate 或看 /var/log/syslog 里有没有 cron 执行记录
  • 容器环境常需额外加 crond 启动,或改用 logrotate -f 主动触发

rotate 之后日志丢了?注意 missingok 和 create 权限冲突

missingok 看似安全,但和 create 一起用容易出问题:如果旧日志被误删、路径不存在,logrotate 会跳过创建新文件(因为 missingok 让它“假装没看见”),导致后续程序写日志失败,看似静默,实则断流。

实操建议:

  • 生产环境慎用 missingok;更稳妥的是用 notifempty 配合 create
  • create 的权限参数要匹配应用用户,比如 nginx 日志常用:create 0644 www-data www-data,而不是 root
  • 若日志路径是软链,logrotate 默认操作目标文件而非链接本身,需加 copycopytruncate 明确行为

按大小 + 时间双条件轮转?logrotate 本身不支持 AND 逻辑

logrotatesizedaily/weekly 是 OR 关系:满足任一即触发。想实现“每 100MB 且至少一天才轮转”,它做不到原生支持。

实操建议:

  • 折中方案:用 size 主控,配合 minage 1(单位天),确保即使写得快,也不会在同一天内多次轮转
  • 极端场景需精确控制,得外挂脚本:先用 stat -c %y /path/to/log 判断修改时间,再决定是否调用 logrotate -f
  • maxagerotate 要配对用,否则老日志删不干净;maxage 按最后修改时间算,不是轮转时间

多个配置文件加载顺序混乱?/etc/logrotate.d/ 下的优先级不等于文件名顺序

logrotate 读取 /etc/logrotate.d/ 下所有文件,但顺序由 glob 展开决定(通常是字典序),不是按修改时间或配置先后。一个服务的日志规则若被另一个文件覆盖(比如都匹配 /var/log/*.log),结果不可控。

实操建议:

  • 每个服务单独配独立文件,文件名用前缀避免冲突,如 nginxmyapp,别叫 01-nginxz-myapp
  • include 显式引入公共片段(如统一压缩命令),避免重复写 compresscmd
  • 调试时加 -d 会打印实际加载的配置块,重点关注 “reading config file” 行,确认哪段生效了

真正麻烦的是嵌套 include 和通配路径重叠——这种时候,logrotate -d 输出里的 “considering log file” 和 “does not need rotating” 就是唯一可信线索。

text=ZqhQzanResources