什么是Docker容器数据卷-古蔺大橙子建站
RELATEED CONSULTING
相关咨询
选择下列产品马上在线沟通
服务时间:8:30-17:00
你可能遇到了下面的问题
关闭右侧工具栏

新闻中心

这里有您想知道的互联网营销解决方案
什么是Docker容器数据卷

这篇文章主要介绍“什么是Docker容器数据卷”,在日常操作中,相信很多人在什么是Docker容器数据卷问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”什么是Docker容器数据卷”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

创新互联建站专注为客户提供全方位的互联网综合服务,包含不限于成都网站设计、网站建设、外贸网站建设、鼎城网络推广、小程序制作、鼎城网络营销、鼎城企业策划、鼎城品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联建站为所有大学生创业者提供鼎城建站搭建服务,24小时服务热线:18980820575,官方网址:www.cdcxhl.com

一 容器数据集卷介绍

先来看看Docker的理念:

  • 将运用与运行的环境打包形成容器运行 ,运行可以伴随着容器,但是我们对数据的要求希望是持久化的

  • 容器之间希望有可能共享数据

Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据做为镜像的一部分保存下来,那么当容器删除后,数据自然也就没有了。为了能保存数据在docker中我们使用卷。
一句话:有点类似我们redis里面的rdb和aof文件

二 作用及特点

卷就是目录或文件,存在于一个或多个容器中,由docker挂载到容器,但不属于联合文件系统,因此能够绕过Union File System提供一些用于持续存储或共享数据的特性:

卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷

特点:

  • 1:数据卷可在容器之间共享或重用数据

  • 2:卷中的更改可以直接生效

  • 3:数据卷中的更改不会包含在镜像的更新中

  • 4:数据卷的生命周期一直持续到没有容器使用它为止

容器的持久化
容器间继承+共享数据

三 数据卷的使用

1 直接命令添加

1.1 命令
docker run -it -v /宿主机目录:/容器内目录 centos /bin/bash
docker run -it -v /宿主机绝对路径目录:/容器内目录      镜像名

docker run -it -v /opt/docker/myDataValume:/data/VolumeContainer centos

命令将在宿主机和容器中分别创建目录 什么是Docker容器数据卷

1.2 查看数据卷是否挂载成功
#docker inspect 容器ID
CONTAINER ID   IMAGE     COMMAND       CREATED         STATUS         PORTS     NAMES
3f1e57169493   centos    "/bin/bash">

什么是Docker容器数据卷

1.3 容器和宿主机之间数据共享
1.4 容器停止退出后,主机修改后数据是否同步

在宿主机内创建文件,启动容器后查看

1.5 命令(带权限,只读)
docker run -it -v /宿主机绝对路径目录:/容器内目录:ro 镜像名  
docker run -it -v /opt/docker/myDataValume:/dataVolumeContainer:ro centos

宿主机端可以对共享文件进行编辑,容器内只读
什么是Docker容器数据卷

查看dockerfile

docker inspect 621e34eea2a3

2 DockerFile添加

2.1 新建/opt/docker并进入
2.2 创建Dockerfile文件并使用VOLUMN指令来给镜像添加一个或多个数据卷
2.3 File构建
FROM centos
VOLUME ["/dataVolumnContainer1","/dataVolumnContainer2"]
CMD echo "finish,----success"
CMD /bin/bash
2.4 build后生成镜像
root@zhanghl:/opt/docker# docker build -f /opt/docker/Dockerfile -t zhl/centos .
Sending build context to Docker daemon  3.584kB
Step 1/4 : FROM centos
 ---> 300e315adb2f
Step 2/4 : VOLUME ["/dataVolumnContainer1","/dataVolumnContainer2"]
 ---> Running in 6c05cec1141f
Removing intermediate container 6c05cec1141f
 ---> b017ed96a615
Step 3/4 : CMD echo "finish,----success"
 ---> Running in 8e2158b75c7d
Removing intermediate container 8e2158b75c7d
 ---> ea3a76a3d696
Step 4/4 : CMD /bin/bash
 ---> Running in 7f2a18bbf3f0
Removing intermediate container 7f2a18bbf3f0
 ---> e4998e64dece
Successfully built e4998e64dece
Successfully tagged zhl/centos:latest
root@zhanghl:/opt/docker# docker images
REPOSITORY     TAG       IMAGE ID       CREATED          SIZE
zhl/centos     latest    e4998e64dece   41 seconds ago   209MB
zhl/mytomcat   1.1       a636ea3caaed   2 days ago       672MB
mongo          latest    995ccc33e58f   6 days ago       449MB
tomcat         latest    c0e850d7b9bb   7 days ago       667MB
hello-world    latest    d1165f221234   7 weeks ago      13.3kB
centos         latest    300e315adb2f   4 months ago     209MB
2.5 run 容器
root@zhanghl:/opt/docker# docker run -it zhl/centos 
[root@9a463e73a1d9 /]# pwd
/
[root@9a463e73a1d9 /]# ls -l
total 56
lrwxrwxrwx   1 root root    7 Nov  3 15:22 bin -> usr/bin
drwxr-xr-x   2 root root 4096 Apr 30 13:14 dataVolumnContainer1
drwxr-xr-x   2 root root 4096 Apr 30 13:14 dataVolumnContainer2
drwxr-xr-x   5 root root  360 Apr 30 13:14 dev
drwxr-xr-x   1 root root 4096 Apr 30 13:14 etc
drwxr-xr-x   2 root root 4096 Nov  3 15:22 home
lrwxrwxrwx   1 root root    7 Nov  3 15:22 lib -> usr/lib
lrwxrwxrwx   1 root root    9 Nov  3 15:22 lib64 -> usr/lib64
drwx------   2 root root 4096 Dec  4 17:37 lost+found
drwxr-xr-x   2 root root 4096 Nov  3 15:22 media
drwxr-xr-x   2 root root 4096 Nov  3 15:22 mnt
drwxr-xr-x   2 root root 4096 Nov  3 15:22 opt
dr-xr-xr-x 260 root root    0 Apr 30 13:14 proc
dr-xr-x---   2 root root 4096 Dec  4 17:37 root
drwxr-xr-x  11 root root 4096 Dec  4 17:37 run
lrwxrwxrwx   1 root root    8 Nov  3 15:22 sbin -> usr/sbin
drwxr-xr-x   2 root root 4096 Nov  3 15:22 srv
dr-xr-xr-x  13 root root    0 Apr 30 13:14 sys
drwxrwxrwt   7 root root 4096 Dec  4 17:37 tmp
drwxr-xr-x  12 root root 4096 Dec  4 17:37 usr
drwxr-xr-x  20 root root 4096 Dec  4 17:37 var
[root@9a463e73a1d9 /]#
2.6 查看对应主机的目录

因为没有指定宿主机的目录,docker会生成默认的目录

root@zhanghl:/home/zhanghl# docker ps
CONTAINER ID   IMAGE        COMMAND                  CREATED         STATUS         PORTS     NAMES
9a463e73a1d9   zhl/centos   "/bin/sh -c /bin/bash"   2 minutes ago   Up 2 minutes             epic_panini
root@zhanghl:/home/zhanghl# docker inspect 9a463e73a1d9

什么是Docker容器数据卷
在宿主机中查看

zhanghl@zhanghl:/var/lib/docker/volumes/1119e11a0e8e98075d0d8f2fc6a01cb27b5a57b47a7b98668b8aa9b534408ab3/_data$ ls
container01.txt

备注: Docker挂载主机目录Docker访问出现cannot open directory .: Permission denied

解决办法:在挂载目录后多加一个--privileged=true参数即可

到此,关于“什么是Docker容器数据卷”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!


当前标题:什么是Docker容器数据卷
网站地址:http://scgulin.cn/article/jgdjeh.html