systemd-journald 内存占用持续上涨的 SystemMaxUse 与 RuntimeMaxUse 配置

发布时间 - 2026-01-29 00:00:00    点击率:
SystemMaxUse限制/var/log/journal/持久化日志磁盘空间,RuntimeMaxUse限制/run/log/journal/tmpfs临时空间;二者互不替代,需正确配置并重载生效,且须关注/run挂载大小与journald内存行为本质。

SystemMaxUse 和 RuntimeMaxUse 到底管什么

SystemMaxUse 控制的是持久化日志(即 /var/log/journal/ 下的文件)占用磁盘空间的上限,只在启用持久化存储时生效;RuntimeMaxUse 管的是运行时日志(/run/log/journal/,重启即丢)的内存/临时空间上限。两者互不覆盖,也不自动 fallback —— 如果你只配了 SystemMaxUse 但没启用持久化,那它根本不会起作用。

  • 持久化需确保 /var/log/journal/ 目录存在且 journald 有写入权限
  • Storage=volatile(默认值之一),SystemMaxUse 完全被忽略
  • RuntimeMaxUse 的“内存”是误导说法:它限制的是 /run 下的 tmpfs 空间,本质仍是磁盘配额(只是挂载在内存文件系统上)

为什么配了还是涨个不停

常见错误是改了配置却没触发重载,或配置位置不对。systemd-journald 只读取 /etc/systemd/journald.conf/etc/systemd/journald.conf.d/*.conf,忽略 /run/usr 下的同名文件。

  • 修改后必须执行 sudo systemctl kill --signal=SIGHUP systemd-journald(不是 systemctl restart,后者会清空运行时日志并可能丢失上下文)
  • 检查是否真生效:运行 journalctl --disk-usage 看当前用量,再用 systemctl show --property=SystemMaxUse,RuntimeMaxUse systemd-journald 确认加载值
  • 注意单位:配置中写 100M 有效,但写 100MB 会被静默忽略(只接受 K/M/G,无 B

RuntimeMaxUse 对内存 RSS 的影响很有限

RuntimeMaxUse 限制的是 /run/log/journal/ 的容量,但它不直接约束 systemd-journald 进程的 RSS 内存。实际观察中,journald 的内存增长更多来自:

  • 日志条目未及时刷盘(尤其高频率短消息场景)
  • ForwardToSyslog=yes 开启时,内部缓冲区叠加 syslog 转发队列
  • MaxRetentionSec= 设得过大,导致索引结构膨胀

单纯调小 RuntimeMaxUse 可能引发频繁轮转和碎片,反而增加 CPU 和内存压力。更有效的做法是搭配 MaxFileSec=1dayMaxRetentionSec=7day 控制生命周期,再配合 SystemMaxUse=500M 防止磁盘耗尽。

真正该盯住的其实是 /run/log/journal 的挂载大小

/run 是 tmpfs,默认占内存的 50%,如果宿主机内存大(比如 64G),/run 可达 32G —— 此时即使 RuntimeMaxUse=100M,journald 仍可能缓存大量未落盘数据,表现为 RSS 持续上涨。

  • 查看当前 /run 大小:findmnt -t tmpfs | grep /run
  • 临时收紧:sudo mount -o remount,size=512M /run
  • 永久修改需在内核启动参数加 systemd.unified_cgroup_hierarchy=1 并调整 /etc/fstabtmpfs 行的 size= 选项

journald 的内存行为高度依赖底层存储策略和系统级挂载限制,光调两个 MaxUse 很难治本。最容易被忽略的是:它从不主动释放已分配的内存页,除非日志被轮转、压缩或显式 journalctl --vacuum-size


# 内存占用  # 持久化存储  # 为什么  # volatile  # signal  # Property  # var  # 的是  # 磁盘空间  # 配了  # 也不  # 很难  # 很有  # 仍是  # 可达  # 只在  # 再用 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】  php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】  Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】  JavaScript实现Fly Bird小游戏  Python文件异常处理策略_健壮性说明【指导】  Laravel怎么做数据加密_Laravel内置Crypt门面的加密与解密功能  javascript基于原型链的继承及call和apply函数用法分析  Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】  文字头像制作网站推荐软件,醒图能自动配文字吗?  详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点  制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  Laravel如何使用Seeder填充数据_Laravel模型工厂Factory批量生成测试数据【方法】  为什么php本地部署后css不生效_静态资源加载失败修复技巧【技巧】  Laravel如何使用Blade组件和插槽?(Component代码示例)  用yum安装MySQLdb模块的步骤方法  如何在建站主机中优化服务器配置?  Firefox Developer Edition开发者版本入口  浅述节点的创建及常见功能的实现  实例解析Array和String方法  SQL查询语句优化的实用方法总结  如何在宝塔面板中创建新站点?  HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】  Laravel如何使用Vite进行前端资源打包?(配置示例)  详解Oracle修改字段类型方法总结  Laravel怎么调用外部API_Laravel Http Client客户端使用  悟空识字如何进行跟读录音_悟空识字开启麦克风权限与录音  Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境  edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】  Windows驱动无法加载错误解决方法_驱动签名验证失败处理步骤  详解Android中Activity的四大启动模式实验简述  深圳网站制作平台,深圳市做网站好的公司有哪些?  动图在线制作网站有哪些,滑动动图图集怎么做?  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  长沙企业网站制作哪家好,长沙水业集团官方网站?  JavaScript常见的五种数组去重的方式  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  Laravel Vite是做什么的_Laravel前端资源打包工具Vite配置与使用  如何在Windows虚拟主机上快速搭建网站?  UC浏览器如何设置启动页 UC浏览器启动页设置方法  Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程  如何快速搭建二级域名独立网站?  Laravel Eloquent性能优化技巧_Laravel N+1查询问题解决  青岛网站建设如何选择本地服务器?  Laravel如何与Pusher实现实时通信?(WebSocket示例)  Laravel如何实现API版本控制_Laravel版本化API设计方案  图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?  5种Android数据存储方式汇总  如何做网站制作流程,*游戏网站怎么搭建?  如何在IIS中新建站点并配置端口与IP地址?