docker 容器数据卷

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才会消失)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值