Docker实战10|实现volum数据卷

上一篇文章中,仔细讲解了Docker是如何改变当前的root文件系统以及mount等操作。

本文继续讲解Docker是如何实现Volum数据卷的。

实现Volume数据卷

获取代码

git clone https://gitee.com/mjreams/docker.git

上一小节介绍了如何使用AUFS包装busybox,从而实现容器和镜像的分离。但是一旦容器退出,容器可写层的所有内容都会被删除。那么,如果用户需要持久化容器里的部分数据该怎么办呢?volume就是用来解决这个问题的。

本节将会介绍如何实现将宿主机的目录作为数据卷挂载到容器中,井且在容器退出后,数据卷中的内容仍然能够保存在宿主机上。

使用 AUFS 创建容器文件系统的实现过程如下。

启动容器的时候:

    1. 创建只读层(busybox);
    1. 创建容器读写层(writeLayer);
    1. 创建挂载点(mnt),并把只读层和读写层挂载到挂载点;
    1. 将挂载点作为容器的根目录。

    容器退出的时候

    1. 卸载挂载点(mnt)的文件系统;
    1. 删除挂载点;
    1. 删除读写层(writeLayer)

本篇内容就是要在这个文件基础上添加绑定宿主机文件夹到饿容器数据卷的功能。

首先,在main_command.go文件的runCommand命令中添加-v标签

cli.StringFlag{
            Name:  "v",
            Usage: "volume",
        },

在Run函数中,把volume传给创建容器的NewParentProcess函数和删除容器文件系统的Delete WorkSpace函数。

run.go

在NewWorkSpace函数中,继续把volume值传给创建容器文件系统的NewWorkSpace方法。

container/container_process.go

创建容器文件系统的过程如下

    1. 创建只读层。
    1. 创建容器读写层
    1. 创建挂载点并把只读层和读写层挂载到挂载点上。
    1. 接下来,首先要判断Volume是否为空,如果是,就表示用户并没有使用挂载标签,结束创建过程。
    1. 如果不为空,则解析volume字符串
    1. 当解析volume字符串返回的字符数组长度为2,并且数据元素均不为空的时候,则执行MountVolume函数来挂载数据卷。
    1. 否则,提示用户创建数据卷输入值不对。

container/volume.go

挂载数据卷的过程如下

    1. 首先,读取宿主机文件目录URL,创建宿主机文件目录(/root/${parentUrl})。
    1. 然后,读取容器挂载点URL,在容器文件系统里创建挂载点C/root/mnt/${containerUrl})。
    1. 最后,把宿主机文件目录挂载到容器挂载点。这样启动容器的过程,对数据卷的处理也就完成了。

container/volume.go

删除容器文件系统的过程如下

    1. 只有在volume不为空,并且解析volume字符串返回的字符数组长度为2,数据元素均不为空的时候,才执行DeleteVolume函数来处理。
    1. 其余的情况仍然使用前面的DeleteMountPoint函数。

DeleteVolume 处理逻辑

    1. 首先,卸载volume挂载点的文件系统(/root/mnt/${containerUrl}),保证整个容器的挂载点没有被使用。
    1. 然后,再卸载整个容器文件系统的挂载点C/root/mnt)。
    1. 最后,删除容器文件系统挂载点。整个容器退出过程中的文件系统处理就结束了。

流程图

验证测试

启动一个容器,把宿主机的/root/volume挂载到容器的/containerVolume目录下。

可以看到/root下多了一个volume文件

容器里执行ls,可以看到多了一个containerVolume

sh-5.1# ls
containerVolume
sh-5.1# 

由于源代码使用的是aufs文件系统,而本地机器是overlay文件系统,因此后续测试流程不再演示,后续本文将会把代码修改成overlay文件系统

相关推荐
南猿北者6 小时前
docker Network(网络)
网络·docker·容器
唔知小罗7 小时前
git config是做什么的?
git
sam-1237 小时前
k8s上部署redis高可用集群
redis·docker·k8s
Fanstay9858 小时前
在Linux中使用Nginx和Docker进行项目部署
linux·nginx·docker
ggaofeng9 小时前
通过命令学习k8s
云原生·容器·kubernetes
death bell9 小时前
Docker基础概念
运维·docker·容器
天幕繁星10 小时前
docker desktop es windows解决vm.max_map_count [65530] is too low 问题
windows·elasticsearch·docker·docker desktop
想学习java初学者11 小时前
Docker Compose部署Kafka(非Zookeeper)
docker·容器·kafka
尝尝你的优乐美12 小时前
Docker部署Vue项目原来可以那么好用
前端·nginx·docker
qq_道可道12 小时前
K8S升级到1.24后,切换运行时导致 dind 构建镜像慢根因定位与解决
云原生·容器·kubernetes