1.是什么
先来看看Docker的理念:
-
将运用与运行的环境打包形成容器运行 ,运行可以伴随着容器,但是我们对数据的要求希望是持久化的
-
容器之间希望有可能共享数据
Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据做为镜像的一部分保存下来,
那么当容器删除后,数据自然也就没有了。
为了能保存数据在docker中我们使用卷。
一句话:有点类似我们Redis里面的rdb和aof文件
2.能干吗
卷就是目录或文件,存在于一个或多个容器中,由docker挂载到容器,但不属于联合文件系统,因此能够绕过Union File System提供一些用于持续存储或共享数据的特性:
卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷
特点:
1:数据卷可在容器之间共享或重用数据
2:卷中的更改可以直接生效
3:数据卷中的更改不会包含在镜像的更新中
4:数据卷的生命周期一直持续到没有容器使用它为止
使用
以centos镜像跑个容器 在数据卷位置 在宿主机/myDataVolume 文件位置 容器 /dataVolumeContainer centos 文件位置
docker run -it -v /myDataVolume:/dataVolumeContainer centos
只读权限(容器只有读的权限)
docker run -it -v /myDataVolume:/dataVolumeContainer:ro centos
docker inspect [容器ID] 查看是否成功
找到下面内容 就是成功了
"Mounts": [
{
"Type": "bind",
"Source": "/myDataVolume", # 宿主机共享文件位置
"Destination": "/dataVolumeContainer", # 容器共享文件位置
"Mode": "",
"RW": true, # 可读写
"Propagation": "rprivate"
}
],
dockerfile
可以自定义创作镜像的文件
docker build -f /mydata/dockerfile -t zzyy/centos .
-f file 指定文件
-t 命名空间
. 在当前目录
VOLUME["/dataVolumeContainer","/dataVolumeContainer2","/dataVolumeContainer3"]
说明:
出于可移植和分享的考虑,用-v 主机目录:容器目录这种方法不能够直接在Dockerfile中实现。
由于宿主机目录是依赖于特定宿主机的,并不能够保证在所有的宿主机上都存在这样的特定目录。
vim Dockerfile 输入下面内容
# volume test
FROM centos
VOLUME ["/dataVolumeContainer1","/dataVolumeContainer2"]
CMD echo "finished,--------success1"
CMD /bin/bash
运行命令
root@wang-virtual-machine:/mydocker# docker build -f /mydocker/Dockerfile -t zzyy/centos .
Sending build context to Docker daemon 2.048kB
Step 1/4 : FROM centos
---> 300e315adb2f
Step 2/4 : VOLUME ["/dataVolumeContainer1","/dataVolumeContainer2"]
---> Running in 64c5c825c32e
Removing intermediate container 64c5c825c32e
---> 341e53b2e802
Step 3/4 : CMD echo "finished,--------success1"
---> Running in 2119f9efca79
Removing intermediate container 2119f9efca79
---> 90fb287eb281
Step 4/4 : CMD /bin/bash
---> Running in e49f7edd5dd3
Removing intermediate container e49f7edd5dd3
---> d5844312258b
Successfully built d5844312258b
Successfully tagged zzyy/centos:latest
REPOSITORY TAG IMAGE ID CREATED SIZE
zzyy/centos latest d5844312258b 21 seconds ago 209MB
atguigu/mytomcat 1.2 b1b8324a0dec 4 hours ago 650MB
tomcat latest 040bdb29ab37 6 weeks ago 649MB
nginx latest f6d0b4767a6c 6 weeks ago 133MB
centos latest 300e315adb2f 2 months ago 209MB
"Mounts": [
{
"Type": "volume",
"Name": "b80080372c5184aa64d251a0655f678e03b9cbdcf6a302966106c6e10b9e486a",
"Source": "/var/lib/docker/volumes/b80080372c5184aa64d251a0655f678e03b9cbdcf6a302966106c6e10b9e486a/_data",
"Destination": "/dataVolumeContainer1",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
},
{
"Type": "volume",
"Name": "e387ebcbb56a7230f2fdd8d6f1aec8d574d458432c7f6613894bf60b65e91583",
"Source": "/var/lib/docker/volumes/e387ebcbb56a7230f2fdd8d6f1aec8d574d458432c7f6613894bf60b65e91583/_data",
"Destination": "/dataVolumeContainer2",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
}
],
宿主机文件位置:
/var/lib/docker/volumes/b80080372c5184aa64d251a0655f678e03b9cbdcf6a302966106c6e10b9e486a/_data
容器文件位置:
/dataVolumeContainer1
–volumes-from 容器间传递共享
命名的容器挂载数据卷,其它容器通过挂载这个(父容器)实现数据共享,挂载数据卷的容器,称之为数据卷容器(可以理解为一个硬盘上连接几个硬盘。其他硬盘继承这个硬盘)
docker run -it --name dc04 --volumes-from dc03 zzyy/centos
dc04容器 挂载 dc03 镜像是zzyy/centos
容器之间配置信息的传递,数据卷的生命周期一直持续到没有容器使用它为止(父容器删除不影响挂载文件,直到引用为0才会消失)