Docker基礎(chǔ)學(xué)習(xí)之?dāng)?shù)據(jù)管理
前言
docker容器中管理數(shù)據(jù)主要有兩種方式,數(shù)據(jù)卷(Data Volumes)和數(shù)據(jù)卷容器(Data Volume Containers),下面我們?cè)敿?xì)介紹Docker中的數(shù)據(jù)管理,有需要的一起來(lái)學(xué)習(xí)學(xué)習(xí)吧。
數(shù)據(jù)卷
數(shù)據(jù)卷是一個(gè)可供容器使用的特殊目錄,它繞過(guò)文件系統(tǒng),可以提供很多有用的特性:
數(shù)據(jù)卷可以在容器之間共享和重用;
對(duì)數(shù)據(jù)卷的修改會(huì)立馬有效;
對(duì)數(shù)據(jù)卷的更新,不會(huì)影響鏡像;
卷會(huì)一直存在,直到?jīng)]有容器使用。
數(shù)據(jù)卷的使用,類似于Linux下對(duì)目錄或文件進(jìn)行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: 無(wú)法訪問(wèn)/data/: 沒(méi)有那個(gè)文件或目錄 [root@localhost ~]# mkdir /data/ [root@localhost ~]# docker run -itd -v /data/:/data1 centos bash 096460f831bfd72b2efc6ba6b7e7bb060152afa49506ef26e0fa3cb03974f8d5
-v
用來(lái)指定掛載目錄
“:”
前面的/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
不管是把容器停掉、還是刪除,數(shù)據(jù)還是存在的
[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
掛載數(shù)據(jù)卷
[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
其實(shí)掛載目錄的時(shí)候可以指定容器name,如果不指定就隨機(jī)定義了。比如上面我們沒(méi)有指定它,就生成了一個(gè)名字為tender_euclid,這個(gè)名字可以使用命令 Docker ps
看最右側(cè)一列。
[root@localhost ~]# docker run -itd --volumes-from tender_euclid centos bash 3222c7c5c45687e0650b699a9291bc50ecc85030acf8f388c1c6a50b0dc67164
這樣我們使用centos鏡像創(chuàng)建了新的容器,并且使用了tender_euclid容器的數(shù)據(jù)卷。
[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
數(shù)據(jù)卷容器
定義數(shù)據(jù)卷容器
有時(shí)候,我們需要多個(gè)容器之間相互共享數(shù)據(jù),類似于linux里面的NFS。所以就可以搭建一個(gè)專門(mén)的數(shù)據(jù)卷容器,然后其他容器直接掛載該數(shù)據(jù)卷。
首先建立數(shù)據(jù)卷容器
[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
其他容器掛載該數(shù)據(jù)卷
[root@localhost ~]# docker run -itd --volumes-from cent_testv centos bash 0a80861145c9a2627618a78db2b7225eba64137d4664d3706e02c1c623cde5e3
注意:使用–volumes-from參數(shù)所掛載數(shù)據(jù)卷的容器自身并不需要保持在運(yùn)行狀態(tài)
[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
利用數(shù)據(jù)卷容器遷移數(shù)據(jù)
數(shù)據(jù)卷的備份
[root@localhost ~]# docker run -itd --volumes-from cent_testv -v /vol_data_backup/:/backup centos bash 4f5bf6f33f2c78197e54e5145824e98bf89d802376e83019c2913b336fbd9d20
首先我們需要使用cent_testv數(shù)據(jù)卷新開(kāi)一個(gè)容器,同時(shí)我們還需要把本地的/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
恢復(fù)
先新建一個(gè)數(shù)據(jù)卷容器,再建一個(gè)新的容器并掛載該數(shù)據(jù)卷容器,然后再把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 ~]#
總結(jié)
docker為數(shù)據(jù)管理提供了充分的支持,并且,使用數(shù)據(jù)卷容器是一個(gè)不錯(cuò)的選擇。以上就是這篇文章的全部?jī)?nèi)容了,希望能對(duì)大家的學(xué)習(xí)或者工作帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流。
相關(guān)文章
docker鏡像倉(cāng)庫(kù)hub.docker.com無(wú)法訪問(wèn)的解決方法
最近許多群友都詢問(wèn)為什么無(wú)法訪問(wèn)Docker鏡像倉(cāng)庫(kù),本文就來(lái)介紹一下docker鏡像倉(cāng)庫(kù)hub.docker.com無(wú)法訪問(wèn)的解決方法,感興趣的可以了解一下2023-08-08詳解Docker創(chuàng)建Mysql容器并通過(guò)命令行連接到容器
本篇文章主要介紹了Docker創(chuàng)建Mysql容器并通過(guò)命令行連接到容器,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-01-01Docker容器實(shí)戰(zhàn)之鏡像與容器的工作原理
這篇文章主要介紹了Docker容器實(shí)戰(zhàn)之鏡像與容器,關(guān)于鏡像與容器的工作原理,下面文章將詳細(xì)介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-05-05Docker之修改/etc/default/docker 里的DOCKER_OPTS參數(shù)不生效問(wèn)題
這篇文章主要介紹了Docker之修改/etc/default/docker 里的DOCKER_OPTS參數(shù)不生效問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09利用Dockerfile優(yōu)化Nestjs構(gòu)建鏡像大小詳情
這篇文章主要介紹了利用Dockerfile優(yōu)化Nestjs構(gòu)建鏡像大小詳情,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-08-08Docker部署Memos服務(wù)的實(shí)現(xiàn)
本文將介紹如何使用Docker部署Memos服務(wù),首先,我們將構(gòu)建Memos服務(wù)的Docker鏡像,然后將在Docker容器中運(yùn)行Memos服務(wù),感興趣的可以了解一下2023-12-12Docker安裝配置MySQL的實(shí)現(xiàn)步驟
MySQL 是最流行的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),在 WEB 應(yīng)用方面 MySQL 是最好的 RDBMS(Relational Database Management System:關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng))應(yīng)用軟件之一。在本教程中,會(huì)帶大家正確安裝配置MySQL在Docker2021-11-11docker資源控制管理Cgroup的實(shí)現(xiàn)
本文主要介紹了docker資源控制管理Cgroup的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07