前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >在linux中迁移Docker默认镜像存储路径解决磁盘空间满的问题

在linux中迁移Docker默认镜像存储路径解决磁盘空间满的问题

原创
作者头像
codetrend
发布2024-04-10 10:02:26
1920
发布2024-04-10 10:02:26
举报
文章被收录于专栏:编程技巧编程技巧

通过yum或者apt安装的docker通常数据存储在 /var/lib/docker/ ,包括镜像、运行数据等。然而这个目录是在根目录下面,容易导致系统盘满了。如果出现这种情况就需要迁移docker的默认目录。

以下基于此说明。

本文使用到的docker版本为 Docker Version: 24.0.5,宿主机为 CentOS 7

不同版本的docker可能操作不一样,请根据实际情况操作。

核实docker版本方法:

代码语言:shell
复制
# 1.查看 Docker 的系统信息:
sudo docker info

迁移docker默认路径

执行脚本

代码语言:shell
复制
# 1. 停止 Docker 服务:
sudo systemctl stop docker
# 2.创建一个新的目录,用于存储 Docker 数据。例如,将数据存储在 /data/docker/data/:
sudo mkdir -p /data/docker/data/
# 3.将当前 /var/lib/docker 目录下的所有数据移动到新目录,修改权限是必须的。
sudo chmod -R 777 /data/docker/data/
# cp -a 可以复制文件的权限等相关属性,否则很容易因为权限无法启动
sudo cp -a /var/lib/docker/* /data/docker/data/
# 4.备份并修改 Docker 配置文件。默认情况下,Docker 使用 /etc/docker/daemon.json 配置文件。如果该文件不存在,请创建它。
sudo cp /etc/docker/daemon.json /etc/docker/daemon.json.backup
sudo vi /etc/docker/daemon.json
# 5.在 daemon.json 文件中,添加或修改 "data-root" 选项,以指向新的存储路径。例如:

{
  "data-root": "/data/docker/data/"
}

# 保存并关闭文件。

# 6.重新启动 Docker 服务:
sudo systemctl start docker
# 现在,Docker 应使用新的存储路径 /data/docker。请确保在启动容器和执行其他 Docker 操作时验证此更改。

如何验证是否迁移成功

要验证 Docker 是否使用了新的存储路径,您可以执行以下命令:

代码语言:shell
复制
# 1.查看 Docker 的系统信息:
# 在输出的信息中,找到“Docker Root Dir”一项。它应该显示新的存储路径,例如 /data/docker/data/。

sudo docker info

# 2.运行一个简单的测试容器:
# 这将运行一个名为 hello-world 的简单 Docker 容器,然后将其删除。运行此命令的目的是确保 Docker 服务正常工作,以及新的存储路径可以用于创建和删除容器。

sudo docker run --rm hello-world

# 3.在新的存储路径中检查文件和文件夹:
# 此命令会列出/data/docker/data/ 目录中的所有文件和文件夹。如果一切正常,您应该看到 Docker 创建的各种文件夹,例如 overlay2、containers、volumes 等。

sudo ls -la /data/docker/data/

关于作者

来自一线全栈程序员nine的探索与实践,持续迭代中。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 迁移docker默认路径
    • 执行脚本
      • 如何验证是否迁移成功
      • 关于作者
      相关产品与服务
      容器服务
      腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档