【Docker】P3 Docker数据卷、宿主机与挂载
创始人
2025-06-01 20:58:11
0

Docker数据卷、宿主机与挂载

  • 数据卷的概念及作用
  • 挂载
  • 宿主机
  • 配置数据卷
  • 挂载操作示例
  • 一个容器挂载多个目录
  • 一个数据卷挂载到两个容器实现容器间的数据共享交换
  • 更多解释


数据卷的概念及作用

由于Docker容器的隔离性:(Docker 容器是一种独立的运行环境)
所以可能会产生如下问题:

  1. Docker容器意外挂了或者被误删了,在容器中的数据,也就挂了。
  2. Docker容器不能和外部机器直接交换文件。
  3. Docker容器与容器之间无法进行数据交互。

为了解决上述三个问题,数据卷 应运而生:

  1. 数据卷是宿主机中一个目录或文件;
  2. 当容器目录和数据卷目录绑定后,对方的修改会立即同步;
  3. 一个数据卷可以被多个容器同时挂载;
  4. 一个容器也可以被挂载多个数据卷;

数据卷的作用:

  1. 容器数据持久化;
  2. 外部机器和容器间接通信;
  3. 容器之间数据交换;

挂载

在 Docker 中,挂载指的是将主机上的文件或目录映射到容器内部的文件系统中。这样可以让容器与主机共享文件系统中的内容,从而实现数据的持久化存储和共享。

docker run -v /host/path:/container/path image_name

这个命令将会将主机上的 /host/path 目录挂载到容器内部的 /container/path 目录中,容器内部的操作可以直接访问该目录。如果主机上的文件或目录发生了变化,容器内部的操作也会立即反映出来。

使用挂载可以实现多个容器之间的数据共享,也可以实现容器与主机之间的数据传递。同时也可以将容器的数据持久化存储到主机上的某个目录中,避免了容器删除后数据的丢失。


宿主机

在 Docker 中,宿主机指的是运行 Docker 引擎的物理机器或虚拟机,也就是 Docker 运行时的宿主操作系统。

当我们在 Docker 中创建一个容器时,该容器是在宿主机的命名空间中运行的,可以使用宿主机的资源,例如 CPU、内存、网络等,并且可以访问宿主机上的文件系统,也可以通过挂载宿主机上的目录来实现数据共享。

因此,在 Docker 中,宿主机扮演着非常重要的角色,它是容器运行的基础,对于容器的性能、稳定性和安全性都有很大的影响。


配置数据卷

# 注意目录必须为绝对路径;
docker run -i -t --name=xhdTest -v /root/data:/root/data_container nginx:latest /bin/bash

具体参数的含义如下:

run:启动一个新容器。
-i:以交互模式运行容器。
-t:直接进入容器,但是退出容器后,容器会自动关闭。
--name=xhd:给容器指定一个名称,这里是 xhd。
-v /root/data:/root/data_container:将主机上的 /root/data 目录挂载到容器内的 /root/data_container 目录,实现宿主机与容器之间的数据共享。
nginx:latest:使用 Nginx 最新版本的镜像。
/bin/bash:在容器中运行 /bin/bash 命令。

综上所述,这个命令的作用是以交互模式启动一个名为 xhd 的容器,将主机上的 /root/data 目录(数据卷)挂载到容器内的 /root/data_container 目录,并在容器中运行 /bin/bash 命令,此时可以通过终端交互操作容器内的文件系统。


挂载操作示例

首先进行挂载

# xhd是容器的名称,/root/data 是数据卷,/root/data_container 是容器目录
sudo docker run -i -t --name=xhd -v /root/data:/root/data_container nginx:latest /bin/bash

然后访问 /root/data

# 进入管理员权限,因为要访问 /root 目录
su root -p
# 然后在宿主机中创建文件,注意不管之前有没有data目录,执行挂载命令时会自动创建
cd /root/data
touch xhd.txt

然后再访问 /root/data_container
访问时发现容器中自动更新了 xhd.txt 文件

# 注意若不在管理员root账户下,需要sudo,若在管理员账户下,可以不进行sudo
# 注意如果跟我上述挂载命令相同,则容器会在退出时自动关闭,相关博文可以看下述链接
sudo docker ps -a
# 然后启动容器, xxx为容器名称
docker start xxx
# 然后进入容器 xxx 是容器名称,比如上述挂载时我创建的容器名称为xhd
sudo docker exec -i -t xxx /bin/bash
# 进入到容器目录下查看
cd ~
cd data_container

docker基本命令大全:https://xu-hongduo.blog.csdn.net/article/details/129700403

然后我们反而行之,我们在容器中创建一个文件,看看是否可以同步到宿主机中

echo xuhongduo > a.txt

然后访问宿主机,发现同步了

ls

由此,我们可以说,宿主机与容器保持了数据的共享与同步;


一个容器挂载多个目录

上述代码我们实现了一个容器挂载一个目录:

# xhd是容器的名称,/root/data 是数据卷,/root/data_container 是容器目录
sudo docker run -i -t --name=xhd -v /root/data:/root/data_container nginx:latest /bin/bash

现在我们尝试一个容器挂载多个目录:

sudo docker run -i -t --name=xhd -v ~/data2:/root/data2 ~/data3:/root/data3 nginx:latest /bin/bash

我们此时将xhd容器中挂载了两对地址;

在这里插入图片描述


一个数据卷挂载到两个容器实现容器间的数据共享交换

sudo docker run -i -t --name=xhd2 -v ~/data2:/root/data2 nginx:latest
sudo docker run -i -t --name=xhd3 -v ~/data2:/root/data2 nginx:latest
# 一个数据卷:~/data;
# 两个容器:xhd2 与 xhd3;
# 两个容器中的两个目录:/root/data2 与 /root/data3

我们在一个容器目录下创建文件,会发现在数据卷以及另一个容器中将会自动更新;


更多解释

若对数据卷,容器与容器目录之间的关系未理解,可以查看如下解释:

# xhd是容器的名称,/root/data 是数据卷,/root/data_container 是容器目录
sudo docker run -i -t --name=xhd -v /root/data:/root/data_container nginx:latest /bin/bash

命令中的 -v /root/data:/root/data_container 参数表示将本地文件系统上的 /root/data 目录挂载到Docker容器内的 /root/data_container 目录,实现了数据卷的功能。
这样,在容器内对 /root/data_container 的修改会同时反映在本地文件系统的 /root/data 目录上,而在本地文件系统上对 /root/data 的修改也会同时反映在容器内的 /root/data_container 目录上。这种方式可以方便地共享数据和文件,使得容器和本地文件系统之间的数据传输更加高效和方便。


数据卷、宿主机与容器

数据卷是Docker中一种用于共享数据和文件的机制,允许将宿主机上的目录或文件挂载到容器中,实现了数据的持久化和共享。

宿主机是指运行Docker引擎的物理机或虚拟机,它是Docker容器的宿主环境。在Docker中,容器可以通过各种方式访问宿主机的资源,如文件、网络、内存等。

容器是Docker中的一个概念,它是一个轻量级、可移植的软件包,包含应用程序及其运行所需的所有依赖项,可以在不同的平台和环境中运行。容器具有高度的隔离性和可移植性,可以方便地进行部署、测试和管理。

数据卷可以将宿主机上的目录或文件挂载到容器中,使得容器和宿主机之间可以方便地共享数据和文件。数据卷可以使用docker run命令的-v参数进行创建和挂载,也可以使用docker volume命令进行管理。数据卷可以实现数据的持久化和共享,可以在容器停止或删除后仍然保留数据,同时也可以实现容器之间的数据共享。


相关内容

热门资讯

【MySQL】锁 锁 文章目录锁全局锁表级锁表锁元数据锁(MDL)意向锁AUTO-INC锁...
【内网安全】 隧道搭建穿透上线... 文章目录内网穿透-Ngrok-入门-上线1、服务端配置:2、客户端连接服务端ÿ...
GCN的几种模型复现笔记 引言 本篇笔记紧接上文,主要是上一篇看写了快2w字,再去接入代码感觉有点...
数据分页展示逻辑 import java.util.Arrays;import java.util.List;impo...
Redis为什么选择单线程?R... 目录专栏导读一、Redis版本迭代二、Redis4.0之前为什么一直采用单线程?三、R...
【已解决】ERROR: Cou... 正确指令: pip install pyyaml
关于测试,我发现了哪些新大陆 关于测试 平常也只是听说过一些关于测试的术语,但并没有使用过测试工具。偶然看到编程老师...
Lock 接口解读 前置知识点Synchronized synchronized 是 Java 中的关键字,...
Win7 专业版安装中文包、汉... 参考资料:http://www.metsky.com/archives/350.htm...
3 ROS1通讯编程提高(1) 3 ROS1通讯编程提高3.1 使用VS Code编译ROS13.1.1 VS Code的安装和配置...
大模型未来趋势 大模型是人工智能领域的重要发展趋势之一,未来有着广阔的应用前景和发展空间。以下是大模型未来的趋势和展...
python实战应用讲解-【n... 目录 如何在Python中计算残余的平方和 方法1:使用其Base公式 方法2:使用statsmod...
学习u-boot 需要了解的m... 一、常用函数 1. origin 函数 origin 函数的返回值就是变量来源。使用格式如下...
常用python爬虫库介绍与简... 通用 urllib -网络库(stdlib)。 requests -网络库。 grab – 网络库&...
药品批准文号查询|药融云-中国... 药品批文是国家食品药品监督管理局(NMPA)对药品的审评和批准的证明文件...
【2023-03-22】SRS... 【2023-03-22】SRS推流搭配FFmpeg实现目标检测 说明: 外侧测试使用SRS播放器测...
有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
初级算法-哈希表 主要记录算法和数据结构学习笔记,新的一年更上一层楼! 初级算法-哈希表...
进程间通信【Linux】 1. 进程间通信 1.1 什么是进程间通信 在 Linux 系统中,进程间通信...
【Docker】P3 Dock... Docker数据卷、宿主机与挂载数据卷的概念及作用挂载宿主机配置数据卷挂载操作示例一个容器挂载多个目...