在使用基于 systemd 的 Linux 系统时,日志系统默认采用 journald 来管理系统日志。相比传统的 rsyslog 或 syslog,journald 支持更高效的二进制格式存储、日志等级过滤、时间范围检索等高级功能。不过,也因此带来一个问题:日志文件可能会不断增长,最终占满磁盘空间。
本文将详细介绍如何查看、限制和清理 journald 日志大小,帮助你有效管理日志空间。
临时日志(系统重启后消失):
1 |
/run/log/journal/ |
持久化日志(永久保留):
1 |
/var/log/journal/ |
如果你希望日志持久化,确保 /var/log/journal 目录存在。可以用如下命令创建:
1 2 3 |
mkdir -p /var/log/journal systemd-tmpfiles --create --prefix /var/log/journal systemctl restart systemd-journald |
日志管理配置文件位于:
1 |
/etc/systemd/journald.conf |
可以设置以下参数来限制日志大小:
1 2 3 4 5 6 |
[Journal] SystemMaxUse=500M # 所有持久化日志最大总大小 SystemKeepFree=100M # 保证磁盘剩余至少 100M 空间 SystemMaxFileSize=50M # 单个日志文件最大限制 SystemMaxFiles=10 # 最多保留 10 个日志文件 RuntimeMaxUse=200M # /run/log/journal 使用的最大空间 |
注意:
- System* 开头表示作用于持久化日志(/var/log/journal)
- Runtime* 开头表示作用于临时日志(/run/log/journal)
配置完成后重启服务生效:
1 |
systemctl restart systemd-journald |
使用以下命令查看日志占用空间:
1 |
journalctl --disk-usage |
输出示例:
1 |
Archived and active journals take up 480.0M in the file system. |
除了配置限制外,你也可以手动清理旧日志:
将总日志占用控制在 200M 以内:
1 |
sudo journalctl --vacuum-size=200M |
删除 7 天以前的日志:
1 |
sudo journalctl --vacuum-time=7d |
仅保留最新的 5 个日志文件:
1 |
sudo journalctl --vacuum-files=5 |
systemd-journald 会收集系统内核日志(来自 kmsg)、标准输出/错误、syslog 消息以及服务单元的日志信息,并统一写入二进制日志文件。
这些日志文件具有以下特点:
这样的机制带来了高效查询和安全性,但也需要特别注意空间管理问题。
虽然 journalctl 使用起来非常方便,但配合以下技巧可以更有效排查问题或导出日志保存。
1 |
journalctl -u nginx.service |
1 |
journalctl --since "2025-06-01" --until "2025-06-10" |
1 |
journalctl -u nginx.service --since today > nginx.log |
1 |
journalctl -f |
检查是否配置文件写错或未生效:
1 |
sudo systemctl restart systemd-journald |
可查看实际生效配置:
1 |
man journald.conf |
或使用:
1 |
systemctl status systemd-journald |
journal 的二进制日志不是直接用 cat 打开的,应使用 journalctl 查看或导出为文本。
可尝试进入 救援模式(rescue) 或使用 LiveCD 挂载系统磁盘,删除 /var/log/journal 中的旧日志文件。
如果你希望定期清理日志,可配合 cron 编写自动清理脚本:
1 2 3 4 |
#!/bin/bash # 清理 7 天前日志,保留空间 journalctl --vacuum-time=7d journalctl --vacuum-size=500M |
保存为 /usr/local/bin/cleanup-journal.sh,并加入定时任务:
1 |
sudo crontab -e |
添加内容:
1 |
0 3 * * * /usr/local/bin/cleanup-journal.sh |
每天凌晨 3 点自动清理日志。
Linux 的 systemd-journald 提供了灵活且强大的日志管理功能,但如果不加以限制,可能导致日志空间无节制增长。通过合理设置 journald.conf,结合手动清理命令,可以在保证日志可用性的同时,有效控制磁盘空间占用。