Docker 数据卷及数据容器
这两天开始学习docker,发现docker确实很强大,让网站部署和维护的效率大大提高。遂准备将手头维护的几个小站,全部docker化。整理的过程中感觉到,docker可以以功能或者进程为单位进行部署和维护,不用再花时间在繁琐的配置上面,但是docker和宿主之间的数据共享以及docker间的数据共享仍然是让人头疼和操心的地方。
几个基本概念:
docker: 一种容器管理技术,这里也指既有的开发工具链。
container: 容器
image: 镜像
volum:卷 [ 译者:卷可以理解成计算机中的文件路径 ]
容器中管理数据主要有两种方式:
数据卷(Data Volumes)
数据卷容器(Data Volume Containers)
数据卷
数据卷是一个可供容器使用的特殊目录,它绕过文件系统,可以提供很多有用的特性:
- 数据卷可以在容器之间共享和重用;
- 对数据卷的修改会立马有效;
- 对数据卷的更新,不会影响镜像;
- 卷会一直存在,直到没有容器使用。
数据卷的使用,类似于Linux下对目录或文件进行mount操作。
挂载本地的目录到容器里
[root@localhost ~]# docker images REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE registry latest 5c929a8b587a 29 hours ago 33.27 MB genesis_centos latest 85bc3a58f134 5 days ago 277.6 MB 192.168.1.179:5000/busybox latest 9967c5ad88de 12 days ago 1.093 MB busybox latest 9967c5ad88de 12 days ago 1.093 MB centos-6-x86 latest 8fca9486a39b 13 days ago 341.3 MB centos_with_net latest 3e8ea8607f08 4 weeks ago 294.9 MB centos latest 9baab0af79c4 6 weeks ago 196.7 MB [root@localhost ~]# ls /data/ ls: 无法访问/data/: 没有那个文件或目录 [root@localhost ~]# mkdir /data/ [root@localhost ~]# docker run -itd -v /data/:/data1 centos bash 096460f831bfd72b2efc6ba6b7e7bb060152afa49506ef26e0fa3cb03974f8d5
- -v 用来指定挂载目录
- “:”前面的/data/为本地目录
- “:”后面的/data1/为容器里的目录
[root@localhost ~]# touch /data/1.txt [root@localhost ~]# echo "test" > /data/1.txt [root@localhost ~]# docker exec -it 09646 bash [root@096460f831bf /]# df -h Filesystem Size Used Avail Use% Mounted on /dev/mapper/docker-253:0-1447735-096460f831bfd72b2efc6ba6b7e7bb060152afa49506ef26e0fa3cb03974f8d5 9.8G 231M 9.0G 3% / tmpfs 936M 0 936M 0% /dev shm 64M 0 64M 0% /dev/shm /dev/mapper/VolGroup-lv_root 35G 6.0G 28G 18% /data1 [root@096460f831bf /]# ls /data1/ 1.txt [root@096460f831bf /]# cat /data1/1.txt test [root@096460f831bf /]# touch /data1/2.txt [root@096460f831bf /]# exit exit [root@localhost ~]# ls /data/ 1.txt 2.txt
不管是把容器停掉、还是删除,数据还是存在的
[root@localhost ~]# docker stop 09646 09646 [root@localhost ~]# ls /data/ 1.txt 2.txt [root@localhost ~]# docker rm 09646 09646 [root@localhost ~]# ls /data/ 1.txt 2.txt
挂载数据卷
[root@localhost ~]# docker run -itd -v /data/:/data1 centos bash e136b27a8e177d878e76c60aafade32df947a60f77b3f95dcaf0680b7ffbc6e8 [root@localhost ~]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES e136b27a8e17 centos "bash" 14 seconds ago Up 13 seconds tender_euclid
其实挂载目录的时候可以指定容器name,如果不指定就随机定义了。比如上面我们没有指定它,就生成了一个名字为tender_euclid,这个名字可以使用命令 Docker ps 看最右侧一列。
[root@localhost ~]# docker run -itd --volumes-from tender_euclid centos bash 3222c7c5c45687e0650b699a9291bc50ecc85030acf8f388c1c6a50b0dc67164
这样我们使用centos镜像创建了新的容器,并且使用了tender_euclid容器的数据卷。
[root@localhost ~]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 3222c7c5c456 centos "bash" 26 seconds ago Up 25 seconds sick_albattani e136b27a8e17 centos "bash" 6 minutes ago Up 6 minutes tender_euclid [root@localhost ~]# docker exec -it 3222 bash [root@3222c7c5c456 /]# df -h Filesystem Size Used Avail Use% Mounted on /dev/mapper/docker-253:0-1447735-3222c7c5c45687e0650b699a9291bc50ecc85030acf8f388c1c6a50b0dc67164 9.8G 231M 9.0G 3% / tmpfs 936M 0 936M 0% /dev shm 64M 0 64M 0% /dev/shm /dev/mapper/VolGroup-lv_root 35G 6.0G 28G 18% /data1 [root@3222c7c5c456 /]# ls /data1/ 1.txt 2.txt [root@3222c7c5c456 /]# touch /data1/3.txt [root@3222c7c5c456 /]# ls -l /data1/ total 4 -rw-r--r--. 1 root root 5 Oct 20 05:53 1.txt -rw-r--r--. 1 root root 0 Oct 20 05:59 2.txt -rw-r--r--. 1 root root 0 Oct 20 06:31 3.txt [root@3222c7c5c456 /]# exit exit [root@localhost ~]# ls /data/ 1.txt 2.txt 3.txt
数据卷容器
定义数据卷容器
有时候,我们需要多个容器之间相互共享数据,类似于linux里面的NFS。所以就可以搭建一个专门的数据卷容器,然后其他容器直接挂载该数据卷。
首先建立数据卷容器
[root@localhost ~]# docker run -itd -v /data/ --name cent_testv centos bash fb45150dbc218e71ff07eca44be3603e004e01b94effcca14c2bd8b3a998f096
注意:这里的/data/是容器的/data目录,并非本地的/data/目录
[root@localhost ~]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES fb45150dbc21 centos "bash" 8 minutes ago Up 8 minutes cent_testv 3222c7c5c456 centos "bash" 52 minutes ago Up 52 minutes sick_albattani e136b27a8e17 centos "bash" 58 minutes ago Up 58 minutes tender_euclid
[root@localhost ~]# docker exec -it cent_testv bash [root@fb45150dbc21 /]# df -h Filesystem Size Used Avail Use% Mounted on /dev/mapper/docker-253:0-1447735-fb45150dbc218e71ff07eca44be3603e004e01b94effcca14c2bd8b3a998f096 9.8G 231M 9.0G 3% / tmpfs 936M 0 936M 0% /dev shm 64M 0 64M 0% /dev/shm /dev/mapper/VolGroup-lv_root 35G 6.0G 28G 18% /data [root@fb45150dbc21 /]# ls /data/ [root@fb45150dbc21 /]# exit exit [root@localhost ~]# ls /data/ 1.txt 2.txt 3.txt
其他容器挂载该数据卷
[root@localhost ~]# docker run -itd --volumes-from cent_testv centos bash 0a80861145c9a2627618a78db2b7225eba64137d4664d3706e02c1c623cde5e3
注意:使用–volumes-from参数所挂载数据卷的容器自身并不需要保持在运行状态
[root@localhost ~]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 0a80861145c9 centos "bash" 3 seconds ago Up 2 seconds mad_carson fb45150dbc21 centos "bash" 14 minutes ago Up 14 minutes cent_testv 3222c7c5c456 centos "bash" 58 minutes ago Up 58 minutes sick_albattani e136b27a8e17 centos "bash" About an hour ago Up About an hour tender_euclid [root@localhost ~]# docker exec -it 0a8086 bash [root@0a80861145c9 /]# df -h Filesystem Size Used Avail Use% Mounted on /dev/mapper/docker-253:0-1447735-0a80861145c9a2627618a78db2b7225eba64137d4664d3706e02c1c623cde5e3 9.8G 231M 9.0G 3% / tmpfs 936M 0 936M 0% /dev shm 64M 0 64M 0% /dev/shm /dev/mapper/VolGroup-lv_root 35G 6.0G 28G 18% /data
[root@0a80861145c9 /]# touch /data/fight.txt [root@0a80861145c9 /]# exit exit [root@localhost ~]# docker exec -it cent_testv bash [root@fb45150dbc21 /]# ls /data/ fight.txt [root@fb45150dbc21 /]# exit exit
利用数据卷容器迁移数据
数据卷的备份
[root@localhost ~]# docker run -itd --volumes-from cent_testv -v /vol_data_backup/:/backup centos bash 4f5bf6f33f2c78197e54e5145824e98bf89d802376e83019c2913b336fbd9d20
首先我们需要使用cent_testv数据卷新开一个容器,同时我们还需要把本地的/vol_data_backup/目录挂载到该容器的/backup下,这样在容器中/backup目录里面新建的文件我们就可以直接在/vol_data_backup/目录中看到了。 然后再把/data/目录下面的文件打包到成data.tar文件放到/backup目录下面。
[root@localhost ~]# docker exec -it 4f5bf bash [root@4f5bf6f33f2c /]# df -h Filesystem Size Used Avail Use% Mounted on /dev/mapper/docker-253:0-1447735-4f5bf6f33f2c78197e54e5145824e98bf89d802376e83019c2913b336fbd9d20 9.8G 231M 9.0G 3% / tmpfs 936M 0 936M 0% /dev shm 64M 0 64M 0% /dev/shm /dev/mapper/VolGroup-lv_root 35G 6.0G 28G 18% /data [root@4f5bf6f33f2c /]# ls /backup/ [root@4f5bf6f33f2c /]# ls /data/ fight.txt [root@4f5bf6f33f2c /]# tar cvf /backup/data.tar /data/ tar: Removing leading `/' from member names /data/ /data/fight.txt [root@4f5bf6f33f2c /]# exit exit [root@localhost ~]# ls /vol_data_backup/ data.tar
恢复
先新建一个数据卷容器,再建一个新的容器并挂载该数据卷容器,然后再把tar包解包。
[root@localhost ~]# docker run -itd -v /data --name cent_testv2 centos bash 4cd696928bbe6e0aec9bf8b6856323d7228eb65006b21849eff9f0d41dcea90f [root@localhost ~]# docker run -itd --volumes-from cent_testv2 -v /vol_data_backup/:/backup centos 7169e8be6d3e5836b626806696046195ed600a1f95b308495e90e6c7b15170d5 [root@localhost ~]# docker exec -it 7169 bash [root@7169e8be6d3e /]# df -h Filesystem Size Used Avail Use% Mounted on /dev/mapper/docker-253:0-1447735-7169e8be6d3e5836b626806696046195ed600a1f95b308495e90e6c7b15170d5 9.8G 231M 9.0G 3% / tmpfs 936M 0 936M 0% /dev shm 64M 0 64M 0% /dev/shm /dev/mapper/VolGroup-lv_root 35G 6.0G 28G 18% /data [root@7169e8be6d3e /]# ls /backup/ data.tar [root@7169e8be6d3e /]# mv /backup/data.tar . [root@7169e8be6d3e /]# ls anaconda-post.log bin data.tar etc lib lost+found mnt proc run srv tmp var backup data dev home lib64 media opt root sbin sys usr [root@7169e8be6d3e /]# tar xvf data.tar data/ data/fight.txt [root@7169e8be6d3e /]# ls /data/ fight.txt [root@7169e8be6d3e /]# exit exit [root@localhost ~]# ls /vol_data_backup/ [root@localhost ~]#
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]