Docker 迁移存储目录
  

Hacking 928

{{ttag.title}}
默认情况系统会将 Docker 容器存放在/var/lib/docker 目录下

问题起因:今天通过监控系统,发现公司其中一台服务器的磁盘快慢,随即上去看了下,发现 /var/lib/docker 这个目录特别大。由上述原因,我们都知道,在 /var/lib/docker 中存储的都是相关于容器的存储,所以也不能随便的将其删除掉。

那就准备迁移 docker 的存储目录吧,或者对 /var 设备进行扩容来达到相同的目的。更多关于 dockerd 的详细参数,请查看官方文档 地址。

但是需要注意的一点就是,尽量不要用软链, 因为一些 docker 容器编排系统不支持这样做,比如我们所熟知的 k8s 就在内。

    # 发现容器启动不了了

    ERROR:cannot create temporary directory!


    # 查看系统存储情况

    $ du -h --max-depth=1

解决方法1:添加软链接

    # 1.停止docker服务

    $ sudo systemctl stop docker


    # 2.开始迁移目录

    $ sudo mv /var/lib/docker /data/


    # 3.添加软链接

    # sudo ln -s /data/docker /var/lib/docker


    # 4.启动docker服务

    $ sudo systemctl start docker

解决方法2:改动 docker 配置文件

    # 3.改动docker启动配置文件

    $ sudo vim /lib/systemd/system/docker.service

    ExecStart=/usr/bin/dockerd --graph=/data/docker/


    # 4.改动docker启动配置文件

    $ sudo vim /etc/docker/daemon.json

    {

        "live-restore": true,

        "graph": [ "/data/docker/" ]

    }

操作注意事项:在迁移 docker 目录的时候注意使用的命令,要么使用 mv 命令直接移动,要么使用 cp 命令复制文件,但是需要注意同时复制文件权限和对应属性,不然在使用的时候可能会存在权限问题。如果容器中,也是使用 root 用户,则不会存在该问题,但是也是需要按照正确的操作来迁移目录。

    # 使用mv命令

    $ sudo mv /var/lib/docker /data/docker


    # 使用cp命令

    $ sudo cp -arv /data/docker /data2/docker

下图中,就是因为启动的容器使用的是普通用户运行进程的,且在运行当中需要使用 /tmp 目录,结果提示没有权限。在我们导入容器镜像的时候,其实是会将容器启动时需要的各个目录的权限和属性都赋予了。如果我们直接是 cp 命令单纯复制文件内容的话,就会出现属性不一致的情况,同时还会有一定的安全问题。

打赏鼓励作者,期待更多好文!

打赏
暂无人打赏

发表新帖
热门标签
全部标签>
西北区每日一问
每日一问
技术盲盒
干货满满
技术笔记
GIF动图学习
通用技术
功能体验
产品连连看
技术咨询
标准化排查
秒懂零信任
高频问题集锦
sangfor周刊
技术晨报
自助服务平台操作指引
畅聊IT
技术圆桌
在线直播
2023技术争霸赛专题
安装部署配置
解决方案
VPN 对接
专家问答
新版本体验
信服课堂视频
答题自测
MVP
网络基础知识
升级
安全攻防
上网策略
测试报告
日志审计
问题分析处理
流量管理
每日一记
运维工具
云计算知识
用户认证
原创分享
项目案例
SANGFOR资讯
专家分享
技术顾问
信服故事
SDP百科
功能咨询
终端接入
授权
设备维护
资源访问
地址转换
虚拟机
存储
迁移
加速技术
排障笔记本
产品预警公告
玩转零信任
信服圈儿
S豆商城资讯
技术争霸赛
「智能机器人」
追光者计划
深信服技术支持平台
社区帮助指南
答题榜单公布
纪元平台
卧龙计划
华北区拉练
天逸直播
以战代练
山东区技术晨报
文档捉虫活动
齐鲁TV
华北区交付直播
每周精选
2024年技术争霸赛
北京区每日一练
场景专题
故障笔记
排障那些事
高手请过招
升级&主动服务
社区新周刊

本版达人

新手89785...

本周建议达人

YangZhe...

本周分享达人