鍍金池/ 問答/Java  PHP  Linux  網(wǎng)絡(luò)安全/ 關(guān)于docker容器里的ip問題?

關(guān)于docker容器里的ip問題?

問題描述:
1、我在容器里面跑我的PHP項(xiàng)目,開始的時(shí)候,容器是綁定的127.0.0.1:8080,但是。我通過瀏覽器訪問:localhost:8080并沒有訪問到服務(wù)器。
2、然后,在容器中,我綁定0.0.0.0:8080。結(jié)果,可以通過localhost:8080訪問服務(wù)器了。
我的疑問是,容器對(duì)ip有沒有做隔離?通過第一步,我感覺容器是隔離了ip,因?yàn)槿萜骼锩娴?27.0.0.1和本機(jī)的127.0.0.1是隔離的,所以訪問服務(wù)器失敗了。因此,我在容器使用了0.0.0.0。但是,對(duì)于第二步,好像又是不對(duì)的。因?yàn)椋词刮胰萜骼锩嬗玫氖?.0.0.0,我在本機(jī)用127.0.0.1卻可以訪問到容器里的服務(wù)器。所以,對(duì)于ip,到底有沒有做隔離?還有就是,如何解釋我前面這兩個(gè)過程遇到的問題?
截圖:

1、容器里面的服務(wù)如下:

clipboard.png
然后,通過瀏覽器訪問容器里面的服務(wù):

clipboard.png

2、容器里面的服務(wù)如下:

clipboard.png
然后,通過瀏覽器訪問容器里面的服務(wù):

clipboard.png

希望前輩們幫我解答一下疑問,謝謝!

回答
編輯回答
別瞎鬧

Docker的四種網(wǎng)絡(luò)模式:

Bridge模式

當(dāng)Docker進(jìn)程啟動(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ò)中。

從docker0子網(wǎng)中分配一個(gè)IP給容器使用,并設(shè)置docker0的IP地址為容器的默認(rèn)網(wǎng)關(guān)。在主機(jī)上創(chuàng)建一對(duì)虛擬網(wǎng)卡veth pair設(shè)備,Docker將veth pair設(shè)備的一端放在新創(chuàng)建的容器中,并命名為eth0(容器的網(wǎng)卡),另一端放在主機(jī)中,以vethxxx這樣類似的名字命名,并將這個(gè)網(wǎng)絡(luò)設(shè)備加入到docker0網(wǎng)橋中??梢酝ㄟ^brctl show命令查看。

bridge模式是docker的默認(rèn)網(wǎng)絡(luò)模式,不寫--net參數(shù),就是bridge模式。使用docker run -p時(shí),docker實(shí)際是在iptables做了DNAT規(guī)則,實(shí)現(xiàn)端口轉(zhuǎn)發(fā)功能??梢允褂胕ptables -t nat -vnL查看。

bridge模式如下圖所示:

clipboard.png

Host模式

如果啟動(dòng)容器的時(shí)候使用host模式,那么這個(gè)容器將不會(huì)獲得一個(gè)獨(dú)立的Network Namespace,而是和宿主機(jī)共用一個(gè)Network Namespace。容器將不會(huì)虛擬出自己的網(wǎng)卡,配置自己的IP等,而是使用宿主機(jī)的IP和端口。但是,容器的其他方面,如文件系統(tǒng)、進(jìn)程列表等還是和宿主機(jī)隔離的。

Host模式如下圖所示:

clipboard.png

Container模式

這個(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è)備通信。

Container模式示意圖:

clipboard.png

None模式

使用none模式,Docker容器擁有自己的Network Namespace,但是,并不為Docker容器進(jìn)行任何網(wǎng)絡(luò)配置。也就是說,這個(gè)Docker容器沒有網(wǎng)卡、IP、路由等信息。需要我們自己為Docker容器添加網(wǎng)卡、配置IP等。

Node模式示意圖:

clipboard.png

更多請(qǐng)自行閱讀: http://www.a-site.cn/article/...

2018年8月31日 20:56