一、容器数据卷是什么
卷就是目录或文件,存在于一个或多个容器中,由docker挂载到容器,但不属于联合文件系统,因此能够绕过Union File System提供一些用于持续存储或共享数据的特性;卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷。
可以将docker容器内的数据保存进宿主机的磁盘中,运行一个带有容器卷存储功能的容器实例:
# docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录 镜像名
二、能干什么
将运用的运行的环境打包镜像,run后形成容器实例运行 ,但是我们对数据的要求希望是持久化的
Docker容器产生的数据,如果不备份,那么当容器实例删除后,容器内的数据自然也就没有了。
为了能保存数据在docker中我们使用卷。
特点:
1:数据卷可在容器之间共享或重用数据
2:卷中的更改可以直接实时生效
3:数据卷中的更改不会包含在镜像的更新中
4:数据卷的生命周期一直持续到没有容器使用它为止
三、数据卷案例
1.宿主机与容器之间添加数据卷
我们这里运行Ubuntu镜像:
# docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录 镜像名
[root@localhost ~]# docker run -it --name=u1 -v /whr/ubuntu/:/tmp/ubuntu --privileged=true ubuntu bash
这里的意思就是运行Ubuntu镜像,并将宿主机下/whr/ubuntu目录挂载到容器u1的/tmp/ubuntu
我们查看u1的详细信息# dicker inspect u1,找到Mounts,就会发现我们挂载的容器数据卷
我们进行测试,在容器的/tmp/ubuntu创建一个目录whr
我们返回到宿主机,在/whr/ubuntu/下查看有没有我们创建的whr
我们发现有whr这个目录,我们再从宿主机上创建一个1.txt,并写一些内容
我们进入容器u1里查看
我们发现也有了内容。
我们测试一下,把u1容器停止,再从宿主机上添加一个文档,再把u1容器启动,进行查看
我们再开启u1,并进入容器实例进行查看
我们可以看到,u1启动后,我们原来在宿主机上写的东西也会一样同步过来。
总结:1 docker修改,主机同步获得
2 主机修改,docker同步获得
3 docker容器stop,主机修改,docker容器重启数据同步。
2.读写规则的设置
读写规则分为读写和只读两种,在默认情况下,就是读写
# docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录:rw 镜像名
下面我们进行只读的限制:容器实例内部被限制,只能读取不能写
# docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录:ro 镜像名
# docker run -it --name=u1 --privileged=true -v /whr/ubuntu/:/tmp/ubuntu:ro ubuntu bash
在容器里进行写,就会提示,文件只读
我们返回宿主机,看看是否能写
宿主机可以完成写,我们再去容器实例查看是否同步
数据已经同步!
3.卷的继承和共享
我们再上一个容器u1的基础上进行配置,对于卷的继承,就是相当于使用原来的容器生成了一个新的一样的容器实例
# docker run -it --privileged=true --volumes-from 父类 --name u2 ubuntu
# docker run -it --name=u2 --privileged=true --volumes-from u1 ubuntu bash
我们看到,u1完全继承了u1的属性以及内容,同样是不能修改文件内容,也是只读属性。