Docker使用数据卷挂载进行数据存储与共享

一、挂载和数据卷

在 Docker 中,挂载(Mounting)和数据卷(Data Volumes)是用于在容器和宿主机之间共享数据的机制。

  • 挂载:将宿主机文件系统中的目录或文件与容器中的目录或文件进行关联的过程。
  • 数据卷:一种特殊的目录,可以绕过容器文件系统,直接与宿主机文件系统进行交互。

1.1 为什么要使用数据卷?

  • 如果数据都在容器中,那么把容器删除以后,数据也会随之丢失,所以要把数据进行数据持久化。
    如:mysql容器,容器删了,里面的数据就都没了
  • 容器之间可以有一个数据共享的技术,使得容器和宿主机实现数据共享。Docker容器中产生的数据,也会同步到宿主机中。

1.2 使用数据卷的好处?

  • 如修改数据库的配置文件还要进入容器里面修改,比较麻烦。当挂载以后只需要在本地修改会即可,容器会自动同步。
    • 挂载以后会占用磁盘两份存储,即容器内占一份,宿主机占一份。
  • 挂载以后,删除容器以后,宿主机对应的挂载目录不会删除。

二、挂载数据卷的方式

可以直接使用docker run -it -v命令来实现数据卷挂载,挂载数据卷命令如下:

powershell 复制代码
docker run -it -v 宿主机路径:容器内路径

其中,宿主机路径为绝对路径,

容器起来以后挂载以后使用docker inspect 容器id 查看目录是否挂载成功

powershell 复制代码
docker inspect 容器id
# 搜索Mounts,这里面就是目录的挂载信息
#   Source:主机内路径
#   Destination:docker容器内的路径
# 如果Mounts这里不展示挂载信息,就说明是挂载失败了

三、具体样例

powershell 复制代码
sudo docker run -it -v /home/Project/data:/data test:1.0

挂载信息如下:

  • 宿主机路径:/home/Project/data
  • 容器路径:/data
  • 镜像名称:image-test:1.0

接下来,我们可以查看容器是否正常启动运行起来:

powershell 复制代码
sudo docker ps -a

查看容器挂载信息:

powershell 复制代码
sudo docker inspect 921ea03a66ea

搜索Mounts,这里面就是目录的挂载信息,其中:

  • Source:主机内路径
  • Destination:docker容器内的路径

如果Mounts这里不展示挂载信息,就说明是挂载失败了。

注意:实现数据卷挂载以后,容器停止以后,往宿主机的挂载目录写入对应的数据,此时数据也会同步到容器内对应的目录。

相关推荐
weixin_4624462320 分钟前
使用 Python 脚本自动化管理 Docker 容器:启动、修改密码、删除及系统资源监控
python·docker·自动化·系统监控
溜达的大象34 分钟前
Navidrome 打造专属无损音乐库,加载cpolar局域网外访问也能超丝滑
阿里云·docker·云原生·eureka
断水客1 小时前
搭建ARM LINUX 内核 QEMU 仿真调试环境
linux·运维·arm开发·嵌入式
fantasy5_51 小时前
深入理解 Linux 动静态库:制作、原理与加载机制
linux·运维·restful
weixin_307779131 小时前
面向通用矩阵乘法(GEMM)负载的GPU建模方法:原理、实现与多场景应用价值
运维·人工智能·线性代数·矩阵·gpu算力
不爱吃糖的程序媛1 小时前
OpenHarmony仓颉文档:全场景应用开发指南
运维·服务器
终端行者1 小时前
Nginx四层负载均衡配置 Stream模块使用
运维·nginx·负载均衡
小程故事多_801 小时前
打破传统桎梏,LLM 让智能运维实现从 “自动化” 到 “自进化”
运维·人工智能·自动化·aigc
oh,huoyuyan2 小时前
火语言 RPA “按住滑块拖动到最右边” 自动化案例
运维·自动化·rpa
龙仔7252 小时前
n2n supernode Linux完整部署笔记,包含离线部署,
linux·运维·笔记·n2n·supernode