设为首页 收藏本站
查看: 914|回复: 0

[经验分享] Docker数据卷

[复制链接]

尚未签到

发表于 2017-12-6 16:38:48 | 显示全部楼层 |阅读模式
  数据卷是一个可以供一个或多个容器使用的特殊目录。
可以达到以下目的:
1. 绕过“拷贝写”系统,以达到本地磁盘IO的性能,(比如运行一个容器,在容器中对数据卷修改内容,会直接改变宿主机上的数据卷中的内容,所以是本地磁盘IO的性能,而不是先在容器中写一份,最后还要将容器中的修改的内容拷贝出来进行同步。)
2. 绕过“拷贝写”系统,有些文件不需要在docker commit打包进镜像文件。
3. 在多个容器间共享目录
4. 在宿主和容器间共享目录
5. 在宿主和容器间共享一个文件。
创建数据卷

  • 方法一:dockerfile中指定VOLUME后的目录,如VOLUME /var/lib/test
  • 方法二:docker run 命令中加-v选项。如
    docker run -d -P -v /webapp training/webapp python app.py注意这里定义的/webapp数据卷,但是不知道宿主机上与之对应的在哪里。我们需要仔细的观察docker inspect docker ps -q的结果,是非常长的一段东西。在这里我只摘出我们需要的部分(过后会找一段时间去查一些关于这个的每个字段的含义。)
    “Mounts”: [
    {
    “Name”: “7dd5c8e5f0dc6f5cd215419a7f5f501b699915cd5e6c2d52c2ecaf1710d1021b”,
    “Source”: “/var/lib/docker/volumes/7dd5c8e5f0dc6f5cd215419a7f5f501b699915cd5e6c2d52c2ecaf1710d1021b/_data”,
    “Destination”: “/webapp”,
    “Driver”: “local”,
    “Mode”: “”,
    “RW”: true,
    “Propagation”: “”
    }
    ],

    “Volumes”: {
    “/webapp”: {}
    },
  注意这里 “Name”: “7dd5c8e5f0dc6f5cd215419a7f5f501b699915cd5e6c2d52c2ecaf1710d1021b”,这个并不是容器id而是数据卷的ID,我们可以在/var/lib/docker/volumes/下找到名子为这个数字的目录。它就是我们数据卷在宿主机上对应的目录。
  当然我们也可以直接挂载宿主机上的目录。给一个例子
[iyunv@VM_116_112_centos /]# docker run -d -P -v .:/webapp training/webapp Python app.py
docker: Error response from daemon: create .: “.” includes invalid characters for a local volume name, only “[a-zA-Z0-9][a-zA-Z0-9_.-]” are allowed.
See ‘docker run –help’.
从给出错误输出我们可以看出,要挂载宿主机上的目录作为数据卷,需要用绝对路径,
[iyunv@VM_116_112_centos gitDockerfile]# ls
abc.txt Dockerfile learnNamespaces README.md webapp
[iyunv@VM_116_112_centos gitDockerfile]# docker run -d -P -v pwd:/webapp training/webapp python app.py
868fcec268d6d351e23168ffd6b3ea621bbcad0bc06cff28e26cbe00e06e3c7f
挂载主机文件作为数据卷
  docker run --rm -it -v 绝对路径 镜像名 执行的指令
docker run --rm -it -v ~/gitDockerfile/abc.txt:/abc.txt ubuntu:14.04 /bin/bash
~/gitDockerfile/abc.txt:/abc.txt这里需要注意一下格式,如果不这样写的话,被挂载的还是目录
数据卷容器
  专门用于挂载数据卷的容器,供其他容器引用,多用于多个容器需要共享同一段数据。用法:–volumes-from。
具体是先创建一个数据卷容器,在创建一个新的容器来引用数据卷容器。
docker run -d -v /dbdata --name=dbdata training/postgres//创建一个数据卷容器
docker run -d --volumes-from dbdata --name=db1 training/postgres//创建一个名为db1的容器并引用dbdata容器
可以用docker inspect 容器 | grep “Source”查看容器的数据卷
docker inspect db1 | grep “Source”
“Source”: “/var/lib/docker/volumes/f9a4a92e2fda5c20fc07759737ea00293723f537d9fad80d11c4bad7621f575e/_data”,
docker inspect dbdata | grep “Source”
“Source”: “/var/lib/docker/volumes/f9a4a92e2fda5c20fc07759737ea00293723f537d9fad80d11c4bad7621f575e/_data”,
  可见这两个容器共享一个数据卷
数据的备份与恢复
  这其实是利用tar命令来执行的。
备份的原理:创建一个数据卷容器,在创建一个引用数据卷容器的新容器,并设置数据卷为本地下的某个目录,并用tar -cvf 命令对数据卷目录进行打压缩。
给一个具体的例子
//创建一个数据卷容器
docker run -d -v /dbdata --name dbdata training/postgres
//创建一个新的容器并引用数据卷容器并备份新的容器
docker run -d --volumes-from dbdata --name db1 -v ~/gitDockergit/backup:/backup ubuntu tar cvf /backup/backup.tar /dbdata
这里来解释一下,以后台的形式运行一个名为db1的容器,它是引用数据卷dbdata的,所以在根下会有个dbdata目录与dbdata容器共享数据卷,而新的db1容器也关联了一个本地的数据卷,所以根下也会有一个backup目录,这里注意关联的必须是绝对路径
~/gitDockergit/backup:/backup这里用一个冒号分割,冒号前的是本地的数据卷位置,是某个目录具体到那个目录,是文件具体到那个文件,冒号后是容器中根下的路径,比如 ~/gitDockergit/backup:/test/backup,那么容器中根下的test目录下有backup目录,这个才是我们的数据卷。
运行完该命令后,我们会发现本地下多处一个backup.tar备份文件。
恢复文件原理:将本地的备份压缩包解压后加载到某个容器中,让其基于备份数据运行。
//创建一个需要恢复数据的容器
docker run -d -v /dbdata --name dbdata2 ubuntu /bin/bash -c "for((i=1;i<100;i++)); do echo 'hello'; sleep 1; done"

//恢复数据
docker run --volumes-from data2 --name db4 -vpwd/backup:/backup busybox tar xvf /backup/backup.tar /dbdata

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-421390-1-1.html 上篇帖子: docker 构建dockerfile 下篇帖子: docker网络解析
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表