社区微信群开通啦,扫一扫抢先加入社区官方微信群
社区微信群
Docker的镜像是由一系列的只读层组合而来,当启动一个容器的时候,Docker加载镜像的所有只读层,并在最上层加入一个读写层。这个设计使得Docker可以提高镜像构建、存储和分发的效率,节省了时间和存储空间,然而也存在如下问题。
(1)容器中的文件在宿主机上存在形式复杂,不能在宿主机上很方便的对容器中的文件进行访问
(2)多个容器之间的数据无法共享
(3)当删除容器时,容器产生的数据将丢失
为了解决这些问题,Docker引入了数据卷(volume)机制。volume是存在一个或多个容器中的特定文件或文件夹,这个目录能够独立于联合文件系统的形式在宿主机中存在,并为数据的共享与持久提供一下便利。
(1)volume在容器创建时就初始化,在容器运行时就可以使用其中的文件
(2)volume能在不同的容器之间共享和重用
(3)对volume中的数据的操作会马上生效
(4)对volume中数据操作不会影响到镜像本身
(5)volume的生存周期独立于容器的生存周期,即使删除容器,volume仍然会存在,没有任何容器使用的volume也不会被Docker删除
1.运行镜像产生容器:
docker run -it --name micheal:v1.0 -v /home/tmp:/home/tmp docker_demo /bin/bash
-d:后台运行
-v:挂在数据卷 使用:ro设置挂在数据卷为只读。如: docker run -it --name micheal:v1.0 -v /home/tmp:/home/tmp:ro docker_demo /bin/bash
当使用-v不指名宿主机的挂在路径的话docker会自行进行分配路径进行挂载;如:
使用命令:docker inspect demo2查看docker自动分配的挂载数据卷位置
多个容器共用一个宿主挂载点:如下命令所示
那么第二条命令 docker_demo4就不会创建成功会出现错误。如果想要新的容器和其他容器共用同一个宿主挂载点那么就只有需要下面的命令:及“--volumes-from 容器名称”
如果挂载源有多个时,可以使用多个--volumes-from相互间隔连接。
上面有测试过,当使用docker commit等手段生成新镜像,然后再启动镜像生成新容器时,原先volume目录下的文件不见了,可以生成新镜像时,并没有把volume下的文件一起打包生成镜像。
volume作为数据的载体,在很多情况下需要对其中的数据进行备份、迁移,或是从已有数据恢复。一个很容易想到的方法就是用docker inspect命令查找到volume对应宿主机上对应的那个目录位置,然后复制其中内容或使用tar打包。当这些笨拙的做法并不值得推荐,因为查找主机上文件夹后再操作容易出错,也不适合脚本的自动化执行。
备份volume可以使用以下方法
docker run --rm --volumes-from dbdata -v $(pwd):/backup test/mycentos:v1.0 tar cvf /back/data.tar /data
这行指令启动了一个临时的容器,这个容器挂载了两个volume,第一个volume与要备份的volume共享,第二个volume将宿主机的当前目录(也可以绝对路径)挂载到容器的/backup下。容器运行后将要备份的容器(/data)备份到/backup/data.tar,然后删除容器,备份后的data.tar就留在了当前目录。操作验证一下
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!