k8s 磁盘不够用,docker数据迁移 导致 /tmp Permission denied,docker优化日志 日志切割, 日志自动删除
创始人
2025-05-30 10:45:03
0

前言

K8s 集群 随着pod运行服务的越来越多,运行时间越来越大,docker目录占用磁盘空间也在逐渐变大,终于在最近磁盘彻底占满导致容器启动不起来并提示"no device space left"。为了防止以后出现docker占用磁盘容量不够的情况决定对docker数据目录迁移。

1. docker数据迁移

docker数据默认存储在/var/lib/docker目录下。实际存储目录可以参考docker info输出

Client:...Server:...Docker Root Dir: var/docker/lib...

迁移步骤

1.1.停止dockerd服务

systemctl stop docker

1.2.创建新目录迁移数据

使用其他挂载盘,使用 cp 命令复制数据

cp -a /var/lib/docker /mnt/data/

注意这里一定要加 -p 或 用 -a 不然复制过去文件权限不对,有些容器启动会报错。如果不加p参数可能会导致迁移后的目录的/tmp目录(其他人&&组)丢失w(写)权限。教训:mongo容器启动需要在/tmp目录下创建****.sock监听请求,由于cp没有加上p参数导致/tmp目录从drwxrwxrwt权限变为drwxr-xr-t权限,无法成功启动。t权限是x+SBIT形成的。

下面举个例子: 变更 docker工作目录后 ,harbor启动异常,报错如下

rsyslogd: run failed with error -3000 (see rsyslog.h or try https://www.rsyslog.com/e/3000 to learn what that number means) rsyslogd: error writing pid file (creation stage) : Permission denied

  • 解决方案

    需要删除所有的容器,已经镜像重新下载镜像运行(数据需要挂载到外面,数据不会丢)

1.3. 编辑docker配置文件

辑配置文件添加一行"data-root": "/mnt/data/docker",
vim /etc/docker/daemon.json

{"registry-mirrors": [],"data-root": "/mnt/data/docker"
}

或者软链接新目录到原来的目录(需要删除原目录或者ln命令加上f参数强行移除)
ln -s /mnt/data/docker /var/lib/docker

1.4. 重启dockerd服务

systemctl start docker

别急着重启,看下docker 日志优化

1.5. 查看是否成功

  • 使用docker info命令查看Docker Root Dir参数是否变为了新的目录
  • 查看容器是否全部启动,如果没有启动可以通过ps -a命令查看exit容器并执行docker start {container_id}或者docker start docker ps -a --filter 'status=exited' --format '{{.ID}}'重启所有退出的容器(该操作会重启已退出但未清除的临时容器,请根据实际情况过滤操作)

2. docker日志优化切割

再 Docker 不重建的情况下,日志文件会默认一直追加,时间长会慢慢的占满服务器硬盘空间。其实就是我们常用的docker logs命令打印的日志会打印到这个目录下的文件之中。

2.1 查看docker默认容器日志驱动

[root@xx-xx log]# docker info|grep 'Logging Driver'Logging Driver: json-file

2.2 查看一个运行中docker容器使用的日志驱动程序

[root@xx-xx log]# docker inspect -f '{{.HostConfig.LogConfig.Type}}' 96a7b67e2581
json-file

2.3 查看一个运行中docker容器使用的日志路径

[root@xx-xx log]# docker inspect -f '{{.LogPath}}' 4ba762e36fca
/mnt/data/docker/containers/4ba762e36fca30509f6052e3374f6975cf13d4066e8cdbe03f832302c80dd3d0/4ba762e36fca30509f6052e3374f6975cf13d4066e8cdbe03f832302c80dd3d0-json.log

可以看到这里的文件就是docker终端打印的日志,所有docker运行久了又不重启,这个日志就越来越大,不清理磁盘肯定炸。

2.4 容器启动时使用–log-driver指定其使用与Docker容器守护进程不同的日志驱动程序

docker run -it --log-driver none xxx

2.5 容器支持的驱动:

驱动名描述
none运行的容器没有日志,docker logs 没有任何输出
local日志以自定义格式存储,旨在实现最小开销
json-file日志格式为 json,docker 的默认日志记录驱动程序
syslog将日志消息写入 syslog。改 syslog 守护程序必须在主机上运行
journald将日志消息写入 journald。该 journald 守护程序必须在主机上运行
gelf将日志消息写入 Graylog 扩展日志格式(GELF)端点,例如 Graylog 或 Logstash。
fluentd将日志消息写入fluentd(转发输入)。该fluentd守护程序必须在主机上运行。
awslogs将日志消息写入 Amazon CloudWatch Logs。
splunk使用 HTTP 事件收集器将日志消息写入splunk
etwlogs将日志消息写为 Windows 事件跟踪(ETW)事件。仅适用于 Windows 平台。
gcplogs将日志消息写入 Google Cloud Platform(GCP)Logging。
logentries将日志消息写入 Rapid7 Logentries。
2.5.1 全局修改日志驱动

修改配置文件/etc/docker/daemon.json

{"log-driver": "none"
}
2.5.2 运行时控制,即在容器启动时添加参数的方式
# max-size 最大数值,必须大于0
# max-file 最大日志数,必须大于0
$ docker run -it --log-opt max-size=10m --log-opt max-file=3 容器名称

2.5.3 全局配置方式

创建或者修改文件/etc/docker/daemon.json,增加如下配置:

{"log-driver":"json-file","log-opts":{"max-size" :"10m","max-file":"20","compress": "true"}
}

由于该配置只对已经生成的容器不生效,将原容器销毁后重新创建

重启Docker服务

sudo systemctl daemon-reload
sudo systemctl restart docker

相关内容

热门资讯

阿联酋最大银行及另两家中东银行... 观点网讯:5月8日,路透社报道指,阿联酋最大银行第一阿布扎比银行(First Abu Dhabi B...
深圳239亿地王易主,再造万象... 2017年,世茂集团豪掷239.43亿元拿下世茂深港国际中心地块,曾规划建筑高度达700米的深圳第一...
蔚来在安庆成立新能源科技公司 ... 天眼查App显示,近日,安庆蔚来新能源科技有限公司成立,法定代表人为姚蒀,注册资本500万人民币,经...
美国牛肉商期盼峰会重启对华出口 据路透社5月8日报道,美国牛肉生产商正期待特朗普与中国于5月14日至15日的峰会推动对华出口许可恢复...
创业板首家未盈利企业,市值突破... 5月8日,大普微总市值正式突破2000亿元大关。截至午间收盘,大普微涨14.07%,报493.1元/...
招商证券:董事长霍达因工作变动... 招商证券公告,公司董事长霍达因工作变动申请辞去董事长、执行董事等全部职务,辞任自辞呈送达董事会之日生...
原创 中... 【阅读须知】本文所引用的所有信息和数据,均为作者通过查阅官方资料与网络公开数据整理、分析而成,旨在为...
原创 从... 2026年5月5日,中国商务部发布了一项具有划时代意义的专项阻断禁令,这份公告让一向倚仗长臂管辖的美...
布米普特拉北京投资基金管理有限... 美国圣路易斯联邦储备银行总裁穆萨莱姆周三发出明确信号,美联储货币政策面临的潜在风险正在发生关键转向。...
加工的秘密:超精加工设备如何做... 你知道吗? 一根头发丝的直径大约0.07毫米,也就是70微米。 超精加工设备,可切出表面,其尺寸为0...
招商证券董事长霍达因工作变动离... 北京商报讯(记者 刘宇阳 实习生 王思奕)5月8日,招商证券发布关于公司董事长离任暨推举董事代行董事...
华帝股份营收创近3年新低,37... 乐居财经李兰近日,华帝股份(002035.SZ)发布2025年年度报告。 2025年,华帝股份实现营...
大模型融资杀疯了!月之暗面狂揽... 图源:视觉中国 5月7日,据华峰资本官微消息,国内头部大模型公司月之暗面(Kimi)于近日完成新一轮...
扎根长宁二十余载,仲利国际融资... 作为总部扎根上海长宁的优质台资金融企业,仲利国际融资租赁有限公司深耕融资租赁行业二十余载,始终坚守金...
估值210亿!李彦宏又将收获一... 来源:直通IPO,文/王非 国产GPU上市潮仍然汹涌,继两家登陆A股、两家登陆H股后,这家公司正推进...
基金“盲盒”拆了 公募基金正在迎来一场让投资者“看得懂”的变革。 近日,华夏、易方达、南方、招商等12家头部及特色基金...
原创 2... 前言 十年间,中国企业在印尼镍产业链累计砸下超过140亿美元,电厂、公路、码头和全套生产线,硬生生...
原创 欧... 俄罗斯卫星通讯社5月6日报道,欧盟宣布禁止欧洲银行为含有来自不可靠供应商的关键部件的可再生能源项目提...
原创 余... 2026年5月2日,在中国理财市场扎根十三年的余额宝,终于触碰到了一个让所有人错愕的数字——7日年化...
银华基金增聘谭普景共同管理银华... 来源:新浪基金∞工作室 5月8日,银华基金管理股份有限公司发布公告称,为银华中证机器人交易型开放式指...