0

0

Linux容器日志暴涨_容器日志治理方案

舞夢輝影

舞夢輝影

发布时间:2026-03-12 15:41:31

|

266人浏览过

|

来源于php中文网

原创

容器日志暴涨是Docker json-file驱动默认不限制所致,需通过控大小、控数量、控源头三方面治理:定位大日志用inspect+ls或lsof;急救可truncate清空或update禁用日志;启动前应在run命令或daemon.json中配置max-size、max-file等参数;应用层须降噪,如调高日志级别、过滤无意义日志、避免异常循环刷屏。

linux容器日志暴涨_容器日志治理方案

容器日志暴涨不是配置遗漏,而是默认行为在生产环境下的必然结果。Docker 使用 json-file 驱动把所有 stdout/stderr 原样转成 JSON 写入本地文件,不设限就等于“无限追加”。关键不在删,而在控——控大小、控数量、控源头。

快速定位问题容器

别一上来就扫全量日志。先聚焦正在疯狂输出的容器:

  • 查日志文件大小:用 docker inspect --format='{{.LogPath}}' <container_id></container_id> 获取路径,再 ls -lh 看实际体积
  • 批量检查所有容器日志:运行 docker ps -q | xargs -I {} sh -c 'echo "=== {} ==="; ls -lh $(docker inspect --format="{{.LogPath}}" {}) 2>/dev/null || echo "no log file"'
  • 结合进程看写入源:lsof +D /var/lib/docker/containers 2>/dev/null | awk '$5 ~ /REG/ && $9 ~ /\.log$/ {print $2,$9}' | sort | uniq -c | sort -nr | head -5,找出占用句柄最多的 PID 和对应容器日志

运行时立即限流(急救)

发现某容器日志已超 2GB?先止血,再治本:

ecshop
ecshop

本版本全面兼容php5.6+,并且修复了许多官方程序的低级代码bug。在apache 2.4.17+php5.6.15环境下测试通过,人格保证无毒无木马,仅仅是一名ecshop热爱者心血来潮之作。ecshop编译更新日志:1、加入最新官方补丁。2、修改数据库连接底层为mysqli, 现在完美无缺了。3、再次对所有代码进行细节修复。4、adminers更新至1.1.2, 在线管理数据库的神器。5、测

下载
  • 对单个容器日志清空(不中断服务):truncate -s 0 $(docker inspect --format='{{.LogPath}}' <container_id>)</container_id>
  • 批量清空所有容器日志:find /var/lib/docker/containers/ -name "*.log" -exec truncate -s 0 {} \;
  • 临时关闭日志输出(慎用):docker update --log-driver=none <container_id></container_id>,之后可重新启用并配限值

启动前强制配置日志策略

靠事后清理是运维灾难。必须在容器启动阶段就固化限制:

  • 运行时指定:docker run --log-driver=json-file --log-opt max-size=50m --log-opt max-file=3 ...
  • 全局默认(推荐):修改 /etc/docker/daemon.json,加入:
    {
      "log-driver": "json-file",
      "log-opts": {
        "max-size": "50m",
        "max-file": "3",
        "compress": "true"
      }
    }
    重启 Docker:sudo systemctl restart docker,此后所有新容器自动继承
  • 对已有容器生效:需 docker commit 镜像后重新 run,或配合 docker update(部分选项支持热更新)

源头治理:应用层降噪

容器日志暴增,80% 源于应用本身。光压日志文件没用,得压输出量:

  • 禁用调试日志:Spring Boot 设置 logging.level.root=WARN;Node.js 应用关闭 DEBUG=* 环境变量
  • 过滤高频无意义日志:Nginx 中加 log_not_found off;,避免每条 404 占一行;Java 应用用 Logback 的 ThresholdFilter 拦截 DEBUG 级别
  • 检查异常循环:如数据库连接失败后每秒重试+打日志,应加退避机制或聚合告警,而非原样刷屏

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

156

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

88

2026.01.26

nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

246

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

522

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

610

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

244

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

693

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3618

2024.08.07

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

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

精品课程

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

共48课时 | 10.5万人学习

Git 教程
Git 教程

共21课时 | 4.2万人学习

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

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