您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)Docker網(wǎng)絡(luò)模式及配置方式的示例,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
docker run 創(chuàng)建 Docker 容器時(shí),可以用 –net 選項(xiàng)指定容器的網(wǎng)絡(luò)模式,Docker 有以下 4 種網(wǎng)絡(luò)模式:
host 模式,使用 –net=host 指定。
container 模式,使用 –net=container:NAME_or_ID 指定。
none 模式,使用 –net=none 指定。
bridge 模式,使用 –net=bridge 指定,默認(rèn)設(shè)置。
如果啟動(dòng)容器的時(shí)候使用 host 模式,那么這個(gè)容器將不會(huì)獲得一個(gè)獨(dú)立的 Network Namespace,而是和宿主機(jī)共用一個(gè) Network Namespace。容器將不會(huì)虛擬出自己的網(wǎng)卡,配置自己的 IP 等,而是使用宿主機(jī)的 IP 和端口。
例如,我們?cè)?10.10.101.105/24 的機(jī)器上用 host 模式啟動(dòng)一個(gè)含有 web 應(yīng)用的 Docker 容器,監(jiān)聽 tcp 80 端口。當(dāng)我們?cè)谌萜髦袌?zhí)行任何類似 ifconfig 命令查看網(wǎng)絡(luò)環(huán)境時(shí),看到的都是宿主機(jī)上的信息。而外界訪問容器中的應(yīng)用,則直接使用 10.10.101.105:80 即可,不用任何 NAT 轉(zhuǎn)換,就如直接跑在宿主機(jī)中一樣。但是,容器的其他方面,如文件系統(tǒng)、進(jìn)程列表等還是和宿主機(jī)隔離的。
這個(gè)模式指定新創(chuàng)建的容器和已經(jīng)存在的一個(gè)容器共享一個(gè) Network Namespace,而不是和宿主機(jī)共享。新創(chuàng)建的容器不會(huì)創(chuàng)建自己的網(wǎng)卡,配置自己的 IP,而是和一個(gè)指定的容器共享 IP、端口范圍等。同樣,兩個(gè)容器除了網(wǎng)絡(luò)方面,其他的如文件系統(tǒng)、進(jìn)程列表等還是隔離的。兩個(gè)容器的進(jìn)程可以通過 lo 網(wǎng)卡設(shè)備通信。
這個(gè)模式和前兩個(gè)不同。在這種模式下,Docker 容器擁有自己的 Network Namespace,但是,并不為 Docker容器進(jìn)行任何網(wǎng)絡(luò)配置。也就是說,這個(gè) Docker 容器沒有網(wǎng)卡、IP、路由等信息。需要我們自己為 Docker 容器添加網(wǎng)卡、配置 IP 等。
bridge 模式是 Docker 默認(rèn)的網(wǎng)絡(luò)設(shè)置,此模式會(huì)為每一個(gè)容器分配 Network Namespace、設(shè)置 IP 等,并將一個(gè)主機(jī)上的 Docker 容器連接到一個(gè)虛擬網(wǎng)橋上。
當(dāng) Docker server 啟動(dòng)時(shí),會(huì)在主機(jī)上創(chuàng)建一個(gè)名為 docker0 的虛擬網(wǎng)橋,此主機(jī)上啟動(dòng)的 Docker 容器會(huì)連接到這個(gè)虛擬網(wǎng)橋上。
虛擬網(wǎng)橋的工作方式和物理交換機(jī)類似,這樣主機(jī)上的所有容器就通過交換機(jī)連在了一個(gè)二層網(wǎng)絡(luò)中。接下來就要為容器分配 IP 了,Docker 會(huì)從 RFC1918 所定義的私有 IP 網(wǎng)段中,選擇一個(gè)和宿主機(jī)不同的IP地址和子網(wǎng)分配給 docker0,連接到 docker0 的容器就從這個(gè)子網(wǎng)中選擇一個(gè)未占用的 IP 使用。
如一般 Docker 會(huì)使用 172.17.0.0/16 這個(gè)網(wǎng)段,并將 172.17.42.1/16 分配給 docker0 網(wǎng)橋(在主機(jī)上使用 ifconfig 命令是可以看到 docker0 的,可以認(rèn)為它是網(wǎng)橋的管理接口,在宿主機(jī)上作為一塊虛擬網(wǎng)卡使用)
docker 容器在啟動(dòng)時(shí)默認(rèn)使用的是bridge 模式,Docker 容器啟動(dòng)后,會(huì)連接到一個(gè)名為 docker0 的虛擬網(wǎng)橋,故每次啟動(dòng)docker容器的IP都不是固定的,不方便管理,有時(shí)候需要進(jìn)行固定IP映射,比如Docker集群管理時(shí)。
Docker容器設(shè)置固定IP時(shí)需要用到需要用到 pipework,用于給容器設(shè)置IP:
$ git clone https://github.com/jpetazzo/pipework.git $ cp pipework/pipework /usr/local/bin/
$ yum -y install bridge-utils
$ brctl addbr br1 $ ip link set dev br1 up $ ip addr add 192.168.10.1/24 dev br1
#基于 centos 這個(gè)鏡像啟動(dòng)一個(gè)容器,名為 centos-ip $ docker run -d --name=centos-ip centos
$ pipework br1 centos-ip 192.168.10.20/24
為名為 centos-ip 的容器指定了IP 192.168.10.20
分別使用 ping 與 ssh 命令進(jìn)行驗(yàn)證,看是否可以ping通和成功登錄
$ ping 192.168.10.20 $ ssh 192.168.10.20
注意:SSH時(shí)需要輸入容器centos的root密碼,如果在創(chuàng)建centos容器時(shí)未指定root密碼,可先進(jìn)入容器設(shè)置root密碼:
docker exec -it 容器ID/NAME sudo passwd root
附: 刪除網(wǎng)橋
brctl show #查看網(wǎng)橋狀態(tài) brctl delif <網(wǎng)橋名> <端口名> #卸載網(wǎng)橋上的端口 ifconfig #查看是否有網(wǎng)橋網(wǎng)卡名 ifconfig <網(wǎng)橋名> down #關(guān)閉此網(wǎng)卡 brctl delbr <網(wǎng)橋名> #刪除網(wǎng)橋</span>
1、創(chuàng)建自定義網(wǎng)絡(luò)
docker network create --subnet=192.168.10.1/24 network_my # docker network ls NETWORK ID NAME DRIVER SCOPE 1fb22da7d8a3 bridge bridge local fe259334b842 host host local 8c5971ff48d8 network_my bridge local 3aaf0356c19c none null local
2、 啟動(dòng)Docker容器
docker run -itd --name hadoop0 --hostname hadoop0 --net network_my --ip 192.168.10.30 -d -P -p 50070:50070 -p 8088:8088 hadoop:master
補(bǔ)充:docker 鏡像源更改與網(wǎng)絡(luò)方式修改
docker 鏡像更改,在/etc/docker/daemon.json 添加鏡像地址,改用別的方式生效了。
{ "exec-opts": ["native.cgroupdriver=systemd"] }
重啟docker
systemctl restart docker systemctl status docker
居然生效了。
docker 的配置時(shí)而這樣生效,時(shí)而那樣生效,真是無語
關(guān)于“Docker網(wǎng)絡(luò)模式及配置方式的示例”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。