目录
1. 数据卷是什么
1.1 运行一个带有容器卷存储功能的容器实例
2.能干什么
3. 容器卷案例
3.1 宿主机vs容器之间映射添加容器卷
3.1.1 命令添加:
3.1.2 查看数据卷是否挂载成功
3.1.3 容器和宿主机之间数据共享
3.2 读写规则映射添加说明
3.2.1 读写(默认)
3.2.2 只读
3.3 卷的继承和共享
3.3.1 容器1完成和宿主机的映射
3.3.2 容器2继承容器1的卷规则
1. 数据卷是什么
有点类似我们Redis里面的rdb和aof文件。
将docker容器内的数据保存进主机的磁盘中。
卷就是目录或文件,存在与一个或多个容器中,由docker挂载到容器,但不属于联合文件系统,因此能够绕过Union File System提供一些用于持续存储或共享数据的特性。
卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷。
1.1 运行一个带有容器卷存储功能的容器实例
docker run -it --name=u1 --privileged=true -v /主机绝对路径目录:/容器内目录 镜像名
docker run -it --name=u1 --privileged=true -v /tmp/host_data:/tmp/docker_data ubuntu
2.能干什么
Docker容器产生的数据,如果不备份,那么当容器实例被删除后,容器内的数据自然也就没有了,为了能保存数据在docker中我们使用卷。
特点:
- 数据卷可在容器之间共享或重用数据
- 卷中的更改可以直接实时生效
- 数据卷中的更改不会包含在镜像的更新中
- 数据卷的生命周期一直持续到没有容器使用它为止
3. 容器卷案例
3.1 宿主机vs容器之间映射添加容器卷
3.1.1 命令添加:
docker run -it --name=u1 --privileged=true -v /主机绝对路径目录:/容器内目录 镜像名
docker run -it --name=u1 --privileged=true -v /tmp/host_data:/tmp/docker_data ubuntu
3.1.2 查看数据卷是否挂载成功
docker inspect 容器ID
"Mounts": [
{
"Type": "bind",
"Source": "/tmp/host_data",
"Destination": "/tmp/docker_data",
"Mode": "",
"RW": true,
"Propagation": "rprivate"
}
],
3.1.3 容器和宿主机之间数据共享
在宿主机上指定的目录下创建一个文件,在docker指定的目录下也会出现。一一映射,双向同步。
如果docker stop之后,在宿主机上添加一个文件 c.txt,再次启动docker,文件c.txt 也会出现在docker 的指定目录下。
3.2 读写规则映射添加说明
3.2.1 读写(默认)
docker run -it --name=myname --privileged=true -v /宿主机绝对路径目录:/容器内目录:rw 镜像名
默认和上节相同,默认就是rw
3.2.2 只读
容器实例内部被限制,只能读取不能写(read only)
docker run -it --name=myname --privileged=true -v /宿主机绝对路径目录:/容器内目录:ro 镜像名
如果宿主机写入内容,是可以同步到容器的。只显示容器的写。
3.3 卷的继承和共享
3.3.1 容器1完成和宿主机的映射
参照上面的映射命令 : docker run -it --name=r1 --privileged=true -v /tmp/u:/tmp/u ubuntu
此时宿主机和容器双向同步。
3.3.2 容器2继承容器1的卷规则
docker run -it --name=r2 --privileged=true --volumes-from 父容器 ubuntu
docker run -it --name=r2 --privileged=true --volumes-from r1 ubuntu
如果在r2 中指定目录创建一个问价,分别在r1和宿主机上的指定目录也会存在。
如果kill r1,在宿主机增加一个文件,此时r2上也会出现。是因为r2继承的是r1挂载路径的规则,r1挂了之后,r2不受影响。
如果再重启启动r1,在r1的指定目录下也会有aa.txt 文件。