我們現在想實現多個容器資料同步,比如多個mysql資料同步,掛載了的容器被稱為父容器。
現在我們先把容器1起一下,用我們上個文章建立的wang/centos
[root@wangstudy _data]# docker run -it --name docker1 wang/centos
[root@5cd8cba5139d /]# ls -l
total 56
lrwxrwxrwx 1 root root 7 may 11 2019 bin -> usr/bin
drwxr-xr-x 5 root root 360 jun 3 10:43 dev
drwxr-xr-x 1 root root 4096 jun 3 10:43 etc
drwxr-xr-x 2 root root 4096 may 11 2019 home
lrwxrwxrwx 1 root root 7 may 11 2019 lib -> usr/lib
lrwxrwxrwx 1 root root 9 may 11 2019 lib64 -> usr/lib64
drwx------ 2 root root 4096 jan 13 21:48 lost+found
drwxr-xr-x 2 root root 4096 may 11 2019 media
drwxr-xr-x 2 root root 4096 may 11 2019 mnt
drwxr-xr-x 2 root root 4096 may 11 2019 opt
dr-xr-xr-x 118 root root 0 jun 3 10:43 proc
dr-xr-x--- 2 root root 4096 jan 13 21:49 root
drwxr-xr-x 11 root root 4096 jan 13 21:49 run
lrwxrwxrwx 1 root root 8 may 11 2019 sbin -> usr/sbin
drwxr-xr-x 2 root root 4096 may 11 2019 srv
dr-xr-xr-x 13 root root 0 may 30 08:43 sys
drwxrwxrwt 7 root root 4096 jan 13 21:49 tmp
drwxr-xr-x 12 root root 4096 jan 13 21:49 usr
drwxr-xr-x 20 root root 4096 jan 13 21:49 var
drwxr-xr-x 2 root root 4096 jun 3 10:43 volume01
drwxr-xr-x 2 root root 4096 jun 3 10:43 volume02
我們再起乙個容器docker2,然後去掛載docker1,可以看到docker2也有這兩個掛載檔案
[root@wangstudy ~]#docker run -it --name docker2 --volume from docker1 wang/centos
[root@8f9b5d163b8f /]# ls -l
total 56
lrwxrwxrwx 1 root root 7 may 11 2019 bin -> usr/bin
drwxr-xr-x 5 root root 360 jun 3 10:43 dev
drwxr-xr-x 1 root root 4096 jun 3 10:43 etc
drwxr-xr-x 2 root root 4096 may 11 2019 home
lrwxrwxrwx 1 root root 7 may 11 2019 lib -> usr/lib
lrwxrwxrwx 1 root root 9 may 11 2019 lib64 -> usr/lib64
drwx------ 2 root root 4096 jan 13 21:48 lost+found
drwxr-xr-x 2 root root 4096 may 11 2019 media
drwxr-xr-x 2 root root 4096 may 11 2019 mnt
drwxr-xr-x 2 root root 4096 may 11 2019 opt
dr-xr-xr-x 118 root root 0 jun 3 10:43 proc
dr-xr-x--- 2 root root 4096 jan 13 21:49 root
drwxr-xr-x 11 root root 4096 jan 13 21:49 run
lrwxrwxrwx 1 root root 8 may 11 2019 sbin -> usr/sbin
drwxr-xr-x 2 root root 4096 may 11 2019 srv
dr-xr-xr-x 13 root root 0 may 30 08:43 sys
drwxrwxrwt 7 root root 4096 jan 13 21:49 tmp
drwxr-xr-x 12 root root 4096 jan 13 21:49 usr
drwxr-xr-x 20 root root 4096 jan 13 21:49 var
drwxr-xr-x 2 root root 4096 jun 3 10:43 volume01
drwxr-xr-x 2 root root 4096 jun 3 10:43 volume02
我們現在往docker1容器裡加檔案,來看docker2是否會存在檔案,發現存在,所有掛載成功。
[root@wangstudy ~]# docker attach 5cd8cba5139d
[root@5cd8cba5139d /]# cd volume01
[root@5cd8cba5139d volume01]# ls
[root@5cd8cba5139d volume01]# touch docker01
[root@5cd8cba5139d volume01]# ls
docker01
[root@5cd8cba5139d volume01]# read escape sequence
[root@wangstudy ~]# docker attach 8f9b5d163b8f
[root@8f9b5d163b8f /]# cd volume01
[root@8f9b5d163b8f volume01]# ls
docker01
現在我們再建立docker3去掛載docker1,同樣存在檔案
[root@wangstudy ~]# docker run -it --name docker3 --volumes-from docker1 wang/centos
[root@7cc24ec1b075 /]# cd volume01
[root@7cc24ec1b075 volume01]# ls
docker01
如此,就實現了容器間資料共享,就算刪掉docker1,資料依舊還在,相當於實現了資料備份。
[root@wangstudy ~]# docker stop 5cd8cba5139d
5cd8cba5139d
[root@wangstudy ~]# docker rm 5cd8cba5139d
5cd8cba5139d
[root@wangstudy ~]# docker ps
container id image command created status ports names
7cc24ec1b075 wang/centos "/bin/sh -c /bin/bash" 6 minutes ago up 6 minutes docker3
8f9b5d163b8f wang/centos "/bin/sh -c /bin/bash" 19 minutes ago up 19 minutes docker2
[root@wangstudy ~]# docker attach 8f9b5d163b8f
[root@8f9b5d163b8f volume01]# ls
docker01 docker03
[root@8f9b5d163b8f volume01]#
Docker 資料卷 資料卷容器
一,概念解析 1,資料卷 資料卷就是在宿主中可以在容器之間進行共享和重用的一系列和檔案和資料夾,通過docker run v命令可以將資料卷掛載到對應的容器目錄空間,進行檔案讀取,容器卷特性如下 資料卷可以在容器之間共享和重用,容器間傳遞資料將變得高效方便 對資料卷內資料的修改會立馬生效,無論是容器...
docker學習(七) 容器資料卷
docker的理念回顧 將應用和環境打包成乙個映象 資料?如果資料在容器中,那麼我們的容器刪除,資料就會丟失!需求 資料持久化!mysql,容器刪了,刪庫跑路!需求 mysql資料可以儲存本地 容器之間可以有乙個資料共享的技術,docker容器中產生的資料同步到本地!這就是卷技術,目錄的掛在,將我們...
Docker學習06 容器資料卷
又來到了乙個新的概念,每次到乙個新的概念,就要問自己 是什麼?有什麼用?怎麼用?能幹嘛?解決了什麼痛點?有什麼優勢?先說乙個坑 docker掛載主機目錄訪問如果出現cannot open directory permission denied,解決方法就是在掛載目錄後多加一條命令 privilege...