docker打开滚动日志
在 Docker 中启用滚动日志(log rotation)可以帮助你管理容器日志的大小,避免日志文件占用过多磁盘空间。以下是具体的操作步骤:
1. 修改 Docker 守护进程配置
Docker 的日志配置是通过 daemon.json
文件管理的。你需要修改此文件以启用滚动日志。
-
打开或创建
daemon.json
文件:sudo vi /etc/docker/daemon.json
-
添加或修改以下内容:
"log-driver": "json-file","log-opts": {"max-size": "50m","max-file": "3"}
max-size
:单个日志文件的最大大小(例如10m
表示 10MB)。max-file
:保留的日志文件数量(例如3
表示保留 3 个日志文件)。
-
保存并退出编辑器。
2. 重启 Docker 服务
使配置生效:
sudo systemctl restart docker
3. 验证配置
-
检查
daemon.json
是否生效:docker info | grep Logging
输出应包含
json-file
和你的日志配置。 -
启动一个容器并检查日志文件:
docker run --name test-container -d busybox sh -c "while true; do echo 'Hello, Docker!'; sleep 1; done"
-
查看日志文件是否滚动:
ls -lh /var/lib/docker/containers/<container-id>/<container-id>-json.log*
你会看到多个日志文件(例如
-json.log
,-json.log.1
,-json.log.2
)。
4. 为单个容器配置日志(可选)
如果你只想为某个容器启用滚动日志,可以在运行容器时指定日志选项:
docker run --name test-container \ --log-driver json-file \ --log-opt max-size=10m \ --log-opt max-file=3 \ -d busybox sh -c "while true; do echo 'Hello, Docker!'; sleep 1; done"
5. 清理旧日志
如果需要手动清理旧日志,可以使用以下命令:
sudo docker logs -f <container-id> > /dev/null 2>&1sudo truncate -s 0 /var/lib/docker/containers/<container-id>/<container-id>-json.log
6. 注意事项
- 日志文件默认存储在
/var/lib/docker/containers/<container-id>/
目录下。 - 如果磁盘空间不足,建议定期清理旧日志或增加
max-size
和max-file
的值。 - 如果你使用其他日志驱动(如
syslog
或journald
),滚动日志的配置方式会有所不同。