什么是Docker容器数据卷

发布时间:2021-10-12 10:58:12 作者:iii
来源:亿速云 阅读:248

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

一 容器数据集卷介绍

先来看看Docker的理念:

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

二 作用及特点

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

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

特点:

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

三 数据卷的使用

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容器数据卷”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

推荐阅读:
  1. docker容器的数据卷使用方法
  2. docker怎么查看容器有什么卷

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

docker

上一篇:如何进行docker CE on Linux中的服务编排

下一篇:什么是Nginx、BIO、NIO、AIO

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》