Docker容器跨主機通信中直接路由方式詳解
概述
就目前Docker自身默認的網絡來說,單臺主機上的不同Docker容器可以借助docker0網橋直接通信,這沒毛病,而不同主機上的Docker容器之間只能通過在主機上用映射端口的方法來進行通信,有時這種方式會很不方便,甚至達不到我們的要求,因此位于不同物理機上的Docker容器之間直接使用本身的IP地址進行通信很有必要。再者說,如果將Docker容器起在不同的物理主機上,我們不可避免的會遭遇到Docker容器的跨主機通信問題。本文就來嘗試一下。
方案原理分析
由于使用容器的IP進行路由,就需要避免不同主機上的容器使用了相同的IP,為此我們應該為不同的主機分配不同的子網來保證。于是我們構造一下兩個容器之間通信的路由方案。
環(huán)境介紹:
主機1的IP地址為:192.168.145.128 主機2的IP地址為:192.168.145.129 為主機1上的Docker容器分配的子網:172.17.1.0/24 為主機2上的Docker容器分配的子網:172.17.2.0/24 這樣配置之后,兩個主機上的Docker容器就肯定不會使用相同的IP地址從而避免了IP沖突。 綜上所述,數(shù)據(jù)包在兩個容器間的傳遞過程如下: 從container1 發(fā)往 container2 的數(shù)據(jù)包,首先發(fā)往container1的“網關”docker0,然后通過查找主機1的路由得知需要將數(shù)據(jù)包發(fā)給主機2,數(shù)據(jù)包到達主機2后再轉發(fā)給主機2的docker0,最后由其將數(shù)據(jù)包轉到container2中;反向原理相同,不再贅述。
1、分別對主機1和主機2上的docker0進行配置
編輯主機1上的 /etc/docker/daemon.json 文件,添加內容:"bip" : "ip/netmask" { "bip", "172.17.1.252/24" } 編輯主機2上的 /etc/docker/daemon.json 文件,添加內容:"bip" : "ip/netmask" { "bip", "172.17.2.252/24" } 重啟docker服務 主機1和主機2上均執(zhí)行如下命令重啟docker服務以使修改后的docker0網段生效 systemctl restart docker
2、添加路由規(guī)則
主機1上添加路由規(guī)則如下: route add -net 172.17.2.0 netmask 255.255.255.0 gw 192.168.145.129 主機2上添加路由規(guī)則如下: route add -net 172.17.1.0 netmask 255.255.255.0 gw 192.168.145.128
3、配置iptables規(guī)則
主機1上添加如下規(guī)則: iptables -t nat -F POSTROUTING iptables -t nat -A POSTROUTING -s 172.17.1.0/24 ! -d 172.17.0.0/16 -j MASQUERADE 主機2上添加如下規(guī)則: iptables -t nat -F POSTROUTING iptables -t nat -A POSTROUTING -s 172.17.2.0/24 ! -d 172.17.0.0/16 -j MASQUERADE
4、啟動容器
主機1上啟動centos容器: docker run -it --name container1 centos /bin/bash 主機2上啟動centos容器: docker run -it --name container2 centos /bin/bash
好了,現(xiàn)在兩容器可以互ping通。
5、路由持久化(防止主機重啟路由丟失)
root@rancher:~# vi /etc/rc.local 添加路由信息,切記寫到exit之前!?。。? route add -net 172.17.2.0 netmask 255.255.255.0 gw 192.168.102.88
以上就是關于Docker容器跨主機通信的全部知識點內容,感謝大家的學習和對腳本之家的支持。
相關文章
Windows?Server?2016中文版安裝docker的詳細步驟
因業(yè)務需要所以需要安裝Docker,但是在途中遇到了一些問題,所以下面這篇文章主要給大家介紹了關于Windows?Server?2016中文版安裝docker的詳細步驟,需要的朋友可以參考下2022-07-07如何修改Docke上傳/下載并發(fā)線程數(shù)來解決docker: unexpected EOF.錯誤問題
下載或上傳鏡像時,有可能因為網絡問題導致報出docker: unexpected EOF.的錯誤,這時候可以考慮通過修改上傳/下載并發(fā)線程數(shù)來解決,本文給大家分享兩種方法幫助大家解決,需要的朋友一起看看吧2023-03-03CentOS7.6系統(tǒng)下Docker安裝部署教程
這篇文章主要為大家介紹了CentOS7.6系統(tǒng)下Docker的安裝部署教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪2022-04-04Docker如何實現(xiàn)修改Docker0網橋默認網段
這篇文章主要介紹了Docker如何實現(xiàn)修改Docker0網橋默認網段,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12Docker之修改/etc/default/docker 里的DOCKER_OPTS參數(shù)不生效問題
這篇文章主要介紹了Docker之修改/etc/default/docker 里的DOCKER_OPTS參數(shù)不生效問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-09-09docker remote api一鍵TLS加密的實現(xiàn)
本文主要介紹了docker remote api一鍵TLS加密的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-11-11Docker命令中的各種參數(shù)使用(run、v、rm、-w、-u、-e)
本文主要介紹了Docker命令中的各種參數(shù)使用(run、v、rm、-w、-u、-e),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-06-06