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

[经验分享] docker-Dockerfile数据卷

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2017-1-24 09:24:30 | 显示全部楼层 |阅读模式
    本章介绍docker是如何把数据管理起来的,在一些业务需要把大量数据或者数据存储起来,默认不随着容器的释放删除,逻辑卷将会变成无容器独立的悬空数据卷,这时就需要用到数据卷的功能,
下面分为两部分:
独立数据卷 (datavalumes)
容器的数据卷(datavalumes container)

wKiom1iF_9CBaBnyAAB2FbpON-0228.jpg

独立数据卷
  • 创建容器的时候会初始化数据卷,如果容器的基础镜像包含的数据在指定的挂载点,现有的数据复制到新卷对卷初始化。
  • 数据卷在容器间是可以共享和重用的。
  • 数据卷的修改是实时的。
  • 更改数据卷并不会影响你已更新的镜像。
  • 独立数据卷不会因为容器删除而消失,不会被docekr进行删除了垃圾回收,当然也不会被再引用

注意:这里全部必须使用绝对路径
数据卷的权限分为:只读(ro),可写(rw默认)
下面的-v和--volumes-from同样作用

挂载独立数据卷
           独立挂载的数据卷必须手动操作,不支持Dockerfile,挂载一个数据卷要使用“-v”这个参数。linux:-v  /local/valumes:/docker/valumes/
windows: -v //c/<path>:/<containerpath>
docker使用“nginx”镜像运行一个名为“web-node1”的容器,
它需要本地的“/data/www”目录以只读模式挂载到容器的“/var/www/html”
把容器80端口映射到本机80端口
1
2
3
4
5
6
7
8
9
10
11
12
docker run -d
-it -v /
data
/www

/var/www/html:ro
--name "
web-node1
" -p 8
0
:80
nginx





创建独立数据卷
给容器添加一个数据卷要使用“-v”这个参数,相当于Dockerfile里面的VALUME
-v /docker/valumes/
1
2
3
4
5
6
7
8
9
10
11
docker
run -d
-it -v
/var/www/html
--name "
web-node1
" -p
8
0
:80
nginx





创建共享数据卷并挂载创建一个具有共享卷的容器,这个容器不会运行任何应用,可以让所有“training/webapp”镜像的容器
重复使用这个共享存储空间,以节省硬盘。
注意:
当你的多个容器使用一个共享卷时,如果多容器同时操作一个文件可能会导致数据损坏。所以当你使用共享卷时一定要确定你已经解决了这个问题。
如果你的容器对IO性能要求高的尽量不要和其它IO频繁的公用。
正常情况docker的数据卷是存储在本机“/var/lib/docker/volumes/”,对于你是可见的,但是尽量不要操作这些文件,否则可能会出现文件损坏
1
2
3
4
[iyunv@salt-node1
nginx-new]#  docker create   -v
/dbdata --name dbstore training/webapp python app.py
f30c468f0ba1514bee62050669b68b7af585e99ac8d2323c4595ca927da47a42




使用共享数据卷
使用--volumes-from调用,通过下面操作你会看到新建的容器是挂载的同样的数据卷。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
[iyunv@salt-node1
nginx-new]#  docker run -d --volumes-from
dbstore --name  web1 training/webapp
629639205d6f0319f1b0c498a17793243e080b02fef74565fdafde36e9d73217
[iyunv@salt-node1
nginx-new]#  docker run -d --volumes-from
dbstore --name  web2 training/webapp
b515337c612a6c4d273c8f8f784b9069cd81bfc34f398c29cb732488c031de0a
[iyunv@salt-node1
nginx-new]# docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS               NAMES
b515337c612a        training/webapp     "python app.py"          9 seconds ago       Up 8 seconds        5000/tcp            web2
629639205d6f        training/webapp     "python app.py"          13 seconds ago      Up 12 seconds       5000/tcp            web1


[iyunv@salt-node1
nginx-new]# docker exec -i web1 /bin/bash
df
Filesystem                                                                                      
1K-blocks     Used Available Use%
Mounted on
/dev/mapper/docker-8:3-78681558-0eef7e30e58c3a5f5a51ebbf9e6f1d44241c474f0b552cf99f5d1dadf614a4e0  10474496  
395236  10079260   4% /
tmpfs                                                                                             
935248        0    935248  
0% /dev
tmpfs                                                                                             
935248        0    935248  
0% /sys/fs/cgroup
/dev/sda3                                                                                       
18555904 13471212   5084692  73% /dbdata
shm                                                                                                
65536        0     65536  
0% /dev/shm
tmpfs                                                                                             
935248        0    935248  
0% /proc/kcore
tmpfs                                                                                             
935248        0    935248  
0% /proc/timer_list
tmpfs                                                                                             
935248        0    935248  
0% /proc/timer_stats
tmpfs                                                                                             
935248        0    935248  
0% /proc/sched_debug
cd /dbdata
ls
touch web1.txt




1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
[iyunv@salt-node1
nginx-new]# docker exec -i web2 /bin/bash
df
Filesystem                                                                                      
1K-blocks     Used Available Use%
Mounted on
/dev/mapper/docker-8:3-78681558-ce6d59337032a1a40292bea3d02007f74e45f98af5dc8cae128a35e1b95ac086  10474496  
395236  10079260   4% /
tmpfs                                                                                             
935248        0    935248  
0% /dev
tmpfs                                                                                             
935248        0    935248  
0% /sys/fs/cgroup
/dev/sda3                                                                                       
18555904 13479920   5075984  73% /dbdata
shm                                                                                                
65536        0     65536  
0% /dev/shm
tmpfs                                                                                             
935248        0    935248  
0% /proc/kcore
tmpfs                                                                                             
935248        0    935248  
0% /proc/timer_list
tmpfs                                                                                             
935248        0    935248  
0% /proc/timer_stats
tmpfs                                                                                             
935248        0    935248  
0% /proc/sched_debug
cd /dbdata
ls
web1.txt






删除容器和数据卷
1
2
3
[iyunv@salt-node1 ~]#
docker rm -v 846953219c6d
846953219c6d





查找悬空数据卷并删除(无容器数据卷)
1
2
3
4
5
6
7
8
9
10
11
12
[iyunv@salt-node1 ~]#
docker volume ls -f dangling=true
DRIVER              VOLUME NAME
local              
0148ef5e61c0ac180cedffbe86269711d3184623fa323965266d3e25c00a38d6
local              
0230fec372cafc4f558320177bbe5b1eaa55ff76782bdf1795ac0d2b4da0f716

[iyunv@salt-node1 ~]#
docker volume rm
0148ef5e61c0ac180cedffbe86269711d3184623fa323965266d3e25c00a38d6
0148ef5e61c0ac180cedffbe86269711d3184623fa323965266d3e25c00a38d6







挂载共享存储作为数据卷
除了使用你本机的目录挂载到容器,你还可以使用docker的插件让你使用一些共享的存储挂载到容器里面
例如: iSCSI, NFS, FC.
使用外部存储的好处就是它独立于主机之外,只要安装了插件并访问到共享存储,容器就能使用它。



运维网声明 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-332733-1-1.html 上篇帖子: docker 1.12-runc源码逻辑跳转流程分析 下篇帖子: Centos6.5上安装docker
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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