Docker - 数据卷挂载与目录挂载的区别

前言

简单记录一下在Docker中,数据卷挂载与目录挂载二者的含义与区别。

一、数据卷挂载

1.什么是数据卷?

数据卷是一个虚拟目录,它将宿主机目录映射到容器内目录,方便我们操作容器内文件,或者方便迁移容器产生的数据。

2.什么是数据卷挂载?

数据卷挂载是将主机上的一个目录或文件作为数据卷挂载到容器中,这个数据卷可以被多个容器共享,容器之间可以通过这个数据卷进行数据交换。数据卷挂载的好处是可以将数据从容器中分离出来,方便备份和迁移,同时也可以避免容器被删除时数据的丢失。

3.如何挂载数据卷?

(1)在创建容器时,利用【-v 数据卷名:容器内目录】完成挂载;

(2)容器创建时,如果发现挂载的数据卷不存在时,会自动创建;

4.数据卷的常见命令有哪些?

(1)docker volume ls # 查看数据卷

(2)docker volume rm # 删除数据卷

(3)docker volume inspect # 查看数据卷详情

(4)docker volume prune # 删除未使用的数据卷

5.如何查看某个容器挂载了哪些数据卷?

(1)docker inspect 容器名

(2)查看返回数据对象中的Mounts键对应的值

二、目录挂载

1.什么是目录挂载?

目录挂载是将主机上的一个目录直接挂载到容器中,容器中的文件会直接覆盖主机上的文件,这种方式不适合多个容器共享数据。目录挂载的好处是可以方便地将主机上的文件或目录与容器中的文件或目录进行同步,方便开发和调试。

2.如何进行目录挂载?

(1)在创建容器时,利用【-v 本地目录:容器内目录】完成挂载;

三、二者区别

数据卷挂载适合多个容器共享数据,而目录挂载适合单个容器与主机之间进行数据交换。

四、提示

(1)注意二者写法上的区别,例如在实例化MySQL容器时挂载写法

javascript 复制代码
-v mysql:/val/lib/mysql 会识别为一个数据卷叫mysql
-v ./mysql:/val/lib/mysql 会识别为当前目录下的mysql目录

(2)当实例化容器时,应查阅官方镜像文档,是否需要配置目录映射

文档地址:Docker Docs

相关推荐
Hello.Reader1 天前
Flink 2.2 Docker 部署Session / Application / SQL Client 一把梭(含 Compose、插件、连接器与踩坑点)
sql·docker·flink
市安1 天前
docker命令知识点1
运维·docker·云原生·容器·eureka
学习3人组1 天前
Docker run 挂载本地两个目录到容器内的写法(核心规则+实操示例)
运维·docker·容器
礼拜天没时间.1 天前
《Docker实战入门与部署指南:从核心概念到网络与数据管理》:初识Docker——概念与优势
linux·运维·网络·docker·容器·centos
潘晓可1 天前
Booklore自建图书馆
docker
optimistic_chen1 天前
【Docker入门】Docker Image(Docker 镜像)
linux·运维·docker·容器·镜像
小林up1 天前
Ubuntu使用阿里云安装docker
ubuntu·阿里云·docker
爱莉希雅&&&1 天前
Docker 超详细全量笔记(含参数解释)
linux·运维·服务器·笔记·docker·容器
橙露1 天前
Docker 容器化运维:镜像优化、容器编排与持久化存储方案
java·运维·docker
TDengine (老段)1 天前
初学者使用 docker 快速体验 TDengine 功能
大数据·物联网·docker·容器·时序数据库·tdengine