容器中的管理数据主要有两种方式:
- 数据卷(Data Volumes): 容器内数据直接映射到本地主机环境;
- 数据卷容器(Data Volume Containers): 使用特定容器维护数据卷。
1.数据卷
数据卷(Data Volumes)是一个可供容器使用的特殊目录,它将主机操作系统目录直接
映射进容器,类似于Linux中的mount行为。
数据卷可以提供很多有用的特性:
- 数据卷可以在容器之间共事和重用,容器间传递数据将变得高效与方便;
- 对数据卷内数据的修改会立马生效,无论是容器内操作还是本地操作;
- 对数据卷的更新不会影响镜像,解摘开应用和数据
- 卷会一直存在,直到没有容器使用,可以安全地卸载它
1.1 创建数据卷
创建命令:
docker volume create -d local test
-d的意思是:Specify volume driver name (default "local")
此时,查看/var/lib/docker/volumes 路径下,会发现所创建的数据卷位置:
[root@localhost ~]# ll /var/lib/docker/volumes/
total 24
-rw-------. 1 root root 32768 Jul 22 17:59 metadata.db
drwxr-xr-x. 3 root root 19 Jul 22 17:59 test
# metadata.db是一个volumes的元数据库文件,不用管它
查看数据卷的详细信息:
[root@localhost ~]# docker volume inspect test
[
{
"CreatedAt": "2019-07-22T17:59:37+08:00",
"Driver": "local",
"Labels": {},
"Mountpoint": "/var/lib/docker/volumes/test/_data",
"Name": "test",
"Options": {},
"Scope": "local"
}
]
volume除了以上介绍的子命令外,还有ls(列出已有数据卷)、prune(清理无用数据卷)、rm(删除数据卷)等。
1.2 绑定数据卷
除了使用 volume 子命令来管理数据卷外,还可以在创建容器时将主机本地的任意路径挂载到容器内作为数据卷,这种形式创建的数据卷称为绑定数据卷。
在用docker [container] run命令的时候,可以使用-mount选项来使用数据卷。
-mount选项支持三种类型的数据卷,包括:
- volume:普通数据卷,映射到主机/var/lib/docker/volumes路径下;
- bind:绑定数据卷,映射到主机指定路径下;
- tmpfs:临时数据卷,只存在于内存中。
下面演示这三种操作示例:
1.2.1 volume
1.创建一个数据卷
docker volume create -d local test
2.启动容器,并绑定该数据卷:
docker run -it --mount type=volume,source=test,destination=/opt centos /bin/bash
该命令可以简写为(老版写法):
docker run -it -v test:/opt centos /bin/bash
3.在容器内部创建一个文件,并编辑信息:
[root@3a99d6382de8 /]# cd /opt/
[root@3a99d6382de8 opt]# echo hello >> a.txt
[root@3a99d6382de8 opt]# cat a.txt
hello
4.在本地操作系统查看该路径的变化:/var/lib/docker/volumes/test/_data
[root@localhost _data]# cd /var/lib/docker/volumes/test/_data/
[root@localhost _data]# ls
a.txt
[root@localhost _data]# cat a.txt
hello
5.在本地操作系统/var/lib/docker/volumes/test/_data路径下创建一个文件,并编辑信息:
[root@localhost _data]# echo docker >> b.txt
[root@localhost _data]# cat b.txt
docker
[root@localhost _data]# ls
a.txt b.txt
6.进入到docker容器中,查看/opt:
[root@3a99d6382de8 opt]# ls
a.txt b.txt
[root@3a99d6382de8 opt]# cat b.txt
docker
该示例说明了:本地操作系统数据卷和容器内的数据挂载点是双向互通联动的,一端改动另一端也会跟着改动。
1.2.2 bind
1.启动容器,并与主机某个目录绑定:
docker run -it --mount type=bind,source=/opt/data/test,destination=/opt centos /bin/bash
该命令可以简写为(老版写法):
docker run -it -v /opt/data/test:/opt centos /bin/bash
注意:/opt/data/test
必需要先创建好。
- 在容器/opt目录下创建文件,并编辑内容:
[root@a6f3b85a996e /]# cd /opt/
[root@a6f3b85a996e opt]# echo hello >> a.txt
[root@a6f3b85a996e opt]# cat a.txt
hello
- 在主机/opt/data/test路径进行查看:
[root@localhost test]# cd /opt/data/test/ && ll
total 4
-rw-r--r--. 1 root root 6 Jul 22 18:35 a.txt
[root@localhost test]# cat a.txt
hello
- 在主机/opt/data/test路径创建文件,并编辑内容:
[root@localhost test]# echo docker >> b.txt
[root@localhost test]# ls
a.txt b.txt
- 在容器/opt目录下进行查看:
[root@a6f3b85a996e opt]# ls
a.txt b.txt
[root@a6f3b85a996e opt]# cat b.txt
docker
该示例说明了:本地操作系统数据目录和容器内的数据挂载点是双向互通联动的,一端改动另一端也会跟着改动。
1.2.3 tmpfs
略
2.数据卷容器
如果用户需要在多个容器之间共享一些持续更新的数据,最简单的方式是使用数据卷容器。数据卷容器也是一个容器,但是它的目的是专门提供数据卷给其他容器挂载。
- 创建一个数据卷容器,并在启动创建数据卷挂载到/opt/data:
docker run -it -v /opt/data --name data-volume --hostname data-volume centos
此处的/opt/data指的是容器内的挂载点,不是主机的。
- 可以在其他容器启动时使用--volumes-from来挂载data-volume容器中的数据卷,例如:
docker run -it --volumes-from data-volume --name web --hostname web centos
- 在web容器的/opt/data目录下新建文件,并编辑内容:
[root@web /]# cd /opt/data/
[root@web data]# echo hello >> a.txt
[root@web data]# cat a.txt
hello
- 在数据卷容器的/opt/data目录下进行查看:
[root@data-volume data]# cd /opt/data/ && ls
a.txt
[root@data-volume data]# cat a.txt
hello
- 在数据卷容器的/opt/data目录下新建文件,并编辑内容:
[root@data-volume data]# echo docker >> b.txt
[root@data-volume data]# ls
a.txt b.txt
- 在web容器的/opt/data目录下进行查看:
[root@web data]# ls
a.txt b.txt
[root@web data]# cat b.txt
docker
该示例说明了:数据卷容器和使用该数据卷容器的容器的数据挂载点是双向互通联动的,一端改动另一端也会跟着改动。
网友评论