0

0

Linux 日志文件失控的治理方案

舞夢輝影

舞夢輝影

发布时间:2026-02-06 16:51:11

|

836人浏览过

|

来源于php中文网

原创

logrotate 配置未生效主因是定时器未触发或规则未被加载;需检查 logrotate.timer 状态、/etc/logrotate.d/ 下文件权限与 include 路径;按大小轮转须避免与 daily 冲突,推荐使用 size、copytruncate、notifempty 和 missingok;journald 和 Docker 日志需分别通过 journald.conf 和 daemon.json 限流。

linux 日志文件失控的治理方案

logrotate 配置写了却没轮转?先查定时器有没有跑

日志文件持续膨胀、logrotate -d /etc/logrotate.conf 手动执行又一切正常——这基本说明配置根本没被触发。不是规则写错了,是压根没进调度队列。

  • systemctl list-timers | grep logrotate:新版 systemd 默认启用 logrotate.timer,如果没看到,说明定时器没注册或被禁用
  • ls -l /etc/logrotate.d/:确认你的规则文件(比如 myapp)确实在这个目录下,且权限是 644(不能是 600755
  • grep -r "include" /etc/logrotate.conf:必须有 include /etc/logrotate.d 这一行,否则所有 /etc/logrotate.d/ 下的文件都会被忽略

按大小切日志,别迷信 daily

一天 1KB 和一天 8GB 的日志,硬按时间轮转毫无意义。用 size 才能真正控住单个文件体积,但参数之间有冲突,一错就失效。

  • size 100Mdaily 不能共存:只要写了 daily,logrotate 就只看时间,size 形同虚设
  • copytruncate 是关键:应用不重开日志句柄时,必须用它,否则轮转后原进程还在往已清空的旧文件写,磁盘空间不释放
  • notifemptymissingok 建议常驻:避免空日志或临时缺失路径导致整个轮转流程中断

示例规则:

/var/log/myapp/app.log {
    size 100M
    rotate 7
    compress
    delaycompress
    copytruncate
    notifempty
    missingok
}

journald 占满几十 GB?别删文件,改配置再 vacuum

/var/log/journal/ 突然飙到 30GB+,不是磁盘坏了,是 systemd-journald 根本没设上限。直接 rm -rf /var/log/journal/* 不但白干,重启后还会重新索引旧日志。

MonkeyCode
MonkeyCode

企业级AI开发平台,全新的AI编程体验,让你的研发团队效率Max

下载
  • 编辑 /etc/systemd/journald.conf,取消注释并设置:
    SystemMaxUse=512M(建议 256–1024M 区间)
    MaxRetentionSec=2week(控制保留时长)
  • 生效命令:sudo systemctl restart systemd-journald
  • 立即释放空间:journalctl --vacuum-size=512M--vacuum-time=2d,比删文件安全十倍

Docker 容器日志爆满?从 daemon.json 开始堵漏

一个容器几小时内打满宿主机磁盘,大概率是 Docker 默认的 json-file 日志驱动没加限制。这不是应用问题,是运行时配置缺位。

  • /etc/docker/daemon.json 中加入:
{
  "log-driver": "json-file",
  "log-opts": {
    "max-size": "10m",
    "max-file": "3"
  }
}
  • 重启生效:sudo systemctl restart docker
  • 验证是否加载:docker inspect --format='{{.HostConfig.LogConfig}}',输出里必须包含 max-sizemax-file
  • 注意:max-size 是单个日志文件上限,max-file 是保留份数,超出后自动轮替删除最老的

真正容易被忽略的是:容器日志路径(/var/lib/docker/containers//-json.log)不在 /var/log 下,常规 logrotate 规则扫不到——必须靠 Docker 自身驱动来管。

相关文章

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

429

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

541

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

313

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

78

2025.09.10

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

864

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

439

2024.06.27

k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

263

2023.07.24

docker进入容器的方法有哪些
docker进入容器的方法有哪些

docker进入容器的方法:1. Docker exec;2. Docker attach;3. Docker run --interactive --tty;4. Docker ps -a;5. 使用 Docker Compose。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

503

2024.04.08

1688阿里巴巴货源平台入口与批发采购指南
1688阿里巴巴货源平台入口与批发采购指南

本专题整理了1688阿里巴巴批发进货平台的最新入口地址与在线采购指南,帮助用户快速找到官方网站入口,了解如何进行批发采购、货源选择以及厂家直销等功能,提升采购效率与平台使用体验。

60

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 8.6万人学习

Git 教程
Git 教程

共21课时 | 3.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号