docker數據管理與網絡通訊之數據卷與數據卷容器

管理Docker容器中數據主要有兩種方式:數據卷和數據卷容器。

數據卷

數據卷是一個供容器使用的特殊目錄,位於容器中,可將宿主機的目錄掛載到數據捲上,雖對數據卷的修改操做馬上可見,而且更新數據不會影響鏡像,從而實現數據在宿主機與容器之間的遷移。數據卷的使用相似於Linux下對目錄進行的mount操做。docker

一、建立數據卷

在docker run 命令中使用-v選項能夠在容器內建立數據卷。屢次使用-v選項可建立多個數據卷。使用--name選項能夠給容器建立一個友好的自定義名稱。centos

下面使用centos鏡像建立一個名爲xxy的容器,而且建立兩個數據卷分別掛載到/data1與/data2目錄上bash

docker pull centos       //下載鏡像
docker run -d -v /data1 -v /data2 --name xxy centos
6f2307a84693aa1bf1bff46858e9f47820be7262c3181167779135c4035bad13
二、掛載主機目錄做爲數據卷

用centos鏡像建立一個名爲xxy1的容器,將宿主機/var/www目錄掛載到容器的/data1目錄上網絡

docker run -v /var/www:/data1 --name xxy1 -it centos /bin/bash

cd /data1
touch test123
exit      //容器的/data1目錄下建立test123文件

cd /var/www
ls            //宿主機對應目錄下也能看到test123文件

docker數據管理與網絡通訊之數據卷與數據卷容器

數據卷容器

數據卷容器就是一個普通的容器,專門提供數據卷給其餘容器掛載使用ide

建立數據卷容器xx,其中所建立的數據卷分別掛載到了/data1與/data2目錄上,使用--volumes-from來掛載xx容器中的數據捲到新的容器,新的容器名爲xx1測試

docker run --name xx -v /data1 -v /data2 -it centos /bin/bash    //建立容器xx

docker run -it --volumes-from xx --name xx1 centos /bin/bash      //建立新容器xx1,掛載xx容器的數據卷
cd data1
touch file
ls
exit         //在xx1數據卷/data1目錄下建立一個文件file

docker exec -it xx /bin/bash
cd data1
ls              //在xx容器中的/data1目錄下能夠查看到,須要開啓xx和xx1兩個容器纔可登錄xx容器

docker數據管理與網絡通訊之數據卷與數據卷容器
docker數據管理與網絡通訊之數據卷與數據卷容器

端口映射

Docker提供端口映射機制來將容器內的服務提供給外部網絡訪問,是指上就是將宿主機的端口映射到容器中,使得外部網絡訪問宿主機的端口即可訪問容器內的服務3d

實現端口映射,須要在運行docker run 命令時使用-P(大寫)選項實現隨機映射,Docker會隨機映射一個端口範圍在49000~49900的端口到容器內部開放的網絡端口code

docker run -d -P httpd:centos       //可以使用docker ps -a查看到本機32768端口映射到了容器中的80端口

可以使用-p(小寫)指定要映射的端口blog

docker run -d -p 49280:80 httpd:centos

docker ps -a

docker數據管理與網絡通訊之數據卷與數據卷容器

容器互聯

簡單說,就是會在源容器和接收容器之間創建一條隧道,接收容器能夠看到源容器指定的信息it

一、建立源容器

docker run -d -P --name qw1 -it httpd:centos /bin/bash

二、建立接收容器,使用--link指定鏈接容器以實現容器互聯

docker run -d -P --name qw2 --link qw1:qw1 -it httpd:centos /bin/bash

三、測試容器互聯
進入容器使用ping命令查看容器是否能互相連通

docker exec -it qw2 /bin/bash
ping qw1

docker數據管理與網絡通訊之數據卷與數據卷容器

相關文章
相關標籤/搜索