Docker是一個非常受歡迎的開源容器化引擎,因其可快速建立、易於管理、保證應用程式的可移植性,而在開發與生產環境中廣泛應用。但是在使用Docker建立一個Web應用時,出現連接埠無法通訊的情況並不少見。今天我們就來分析一下Docker建置的web連接埠不通的原因及解決方案。
一、原因分析
Linux系統中預設開啟了iptables防火牆服務,如果你沒有設定過,防火牆可能會阻止你的docker容器與外部網路通訊。因此,可以透過關閉防火牆或新增規則的方式使得Docker可以順利的與外部網路進行通訊。以下是參考指令:
關閉防火牆: $ sudo service iptables stop
#開放埠: $ sudo iptables -A INPUT -p tcp --dport 80 -j ACCEPT
Docker啟動容器後,透過連接埠對映將容器內的連接埠對應到主機上的一個端口,以實現容器與外部網路的通訊。預設情況下,容器的網路是獨立的,僅對內部進行通訊。因此,如果你沒有對容器內部的連接埠進行映射,可能會導致連接埠無法通訊的問題。以下是預設映射埠的方式:
$ docker run -p 80:80 image-name
Docker中有三種網路驅動,分別是bridge、host和none。在使用Docker容器時,預設使用的是bridge網路驅動,使其形成一個基於NAT網路的虛擬網路。如果你的容器無法存取外部網絡,可能需要檢查你的網路驅動是否選擇正確。可以使用以下指令查看網路驅動程式:
$ docker network ls
Docker啟動容器後,會根據網路驅動為其分配一個唯一的IP位址。如果你的容器IP位址無法存取外部網絡,就需要檢查與之相連的網卡是否正確配置。在下列範例中,我們可以看到容器的IP位址是172.17.0.2:
$ docker inspect container-name | grep IPAddress
二、解決方法
可以使用以下方式檢視連接埠的對應關係:
#$ docker port container-name
輸出的內容應該是:
80/tcp -> 0.0.0.0:80
#上述指令可以查看容器內部的連接埠對應到宿主機器上的連接埠。
可以使用以下方式檢視容器使用的網路類型:
$ docker inspect container-name | grep NetworkMode
如果輸出為bridge,則表示網路驅動已選擇正確。如果輸出為host或none,可以按照下面的方式進行更改:
更改網路類型為bridge:
$ docker run --network bridge image-name
可以在執行Docker指令時,增加一個--privileged參數,使得Docker容器擁有比較高的權限:
$ docker run --privileged image-name
可以使用下列指令查看容器IP位址:
$ docker inspect container -name | grep IPAddress
如果你的容器IP位址改變了,可以使用以下指令重新指定一個唯一的IP位址:
$ docker run --ip 172.17.0.10 image-name
總之,當你的Docker啟動的Web應用連接埠無法通訊時,首先應該排查是哪種原因導致了這種情況,然後透過相應的方式去解決問題。希望這篇文章能夠幫助大家。
以上是docker搭建的web連接埠不通怎麼辦的詳細內容。更多資訊請關注PHP中文網其他相關文章!