日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Docker容器间通讯,直接路由方式实现网络通讯

發(fā)布時間:2024/9/27 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Docker容器间通讯,直接路由方式实现网络通讯 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

參考:https://yq.aliyun.com/articles/602107,修改其中的一個錯誤點。按照自己的方式整理的博文。


此時兩臺主機上的Docker容器如何直接通過IP地址進行通信?

一種直接想到的方案便是通過分別在各自主機中 添加路由 來實現(xiàn)兩個centos容器之間的直接通信。

方案原理分析

由于使用容器的IP進行路由,就需要避免不同主機上的容器使用了相同的IP,為此我們應(yīng)該為不同的主機分配不同的子網(wǎng)來保證。于是我們構(gòu)造一下兩個容器之間通信的路由方案,如下圖所示。

各項配置如下:
? 主機1的IP地址為:192.168.18.162
? 主機2的IP地址為:192.168.18.141
? 為主機1上的Docker容器分配的子網(wǎng):192.168.100.0/24
? 為主機2上的Docker容器分配的子網(wǎng):192.168.200.0/24
這樣配置之后,兩個主機上的Docker容器就肯定不會使用相同的IP地址從而避免了IP沖突。
我們接下來 定義兩條路由規(guī)則 即可:
? 所有目的地址為192.168.100.0/24的包都被轉(zhuǎn)發(fā)到主機1上
? 所有目的地址為192.168.200.0/24的包都被轉(zhuǎn)發(fā)到主機2上
綜上所述,數(shù)據(jù)包在兩個容器間的傳遞過程如下:
? 從container1 發(fā)往 container2 的數(shù)據(jù)包,首先發(fā)往container1的“網(wǎng)關(guān)”docker0,然后通過查找主機1的路由得知需要將數(shù)據(jù)包發(fā)給主機2,數(shù)據(jù)包到達主機2后再轉(zhuǎn)發(fā)給主機2的docker0,最后由其將數(shù)據(jù)包轉(zhuǎn)到container2中;反向原理相同,不再贅述。
我們心里方案想的是這樣,接下來實踐一下看看是否可行。

實際試驗
? 1. 分別對主機1和主機2上的docker0進行配置
編輯主機1上的 /etc/docker/daemon.json 文件,添加內(nèi)容:”bip” : “ip/netmask”

{ "bip":"192.168.100.252/24" }

編輯主機2上的 /etc/docker/daemon.json 文件,添加內(nèi)容:”bip” : “ip/netmask”

{ "bip":"192.168.200.252/24" }

? 2. 重啟docker服務(wù)
主機1和主機2上均執(zhí)行如下命令重啟docker服務(wù)以使修改后的docker0網(wǎng)段生效

systemctl restart docker

? 3. 添加路由規(guī)則
主機1上添加路由規(guī)則如下:

route add -net 192.168.200.0 netmask 255.255.255.0 gw 192.168.18.141

主機2上添加路由規(guī)則如下:

route add -net 192.168.100.0 netmask 255.255.255.0 gw 192.168.18.162

? 4. 配置iptables規(guī)則
主機1上添加如下規(guī)則:

iptables -t nat -F POSTROUTING iptables -t nat -A POSTROUTING -s 192.168.100.0/24 ! -d 192.168.0.0/16 -j MASQUERADE

主機2上添加如下規(guī)則:

iptables -t nat -F POSTROUTING iptables -t nat -A POSTROUTING -s 192.168.200.0/24 ! -d 192.168.0.0/16 -j MASQUERADE

? 5. 啟動容器
主機1上啟動centos容器:

docker run -it --name container1 centos /bin/bash

主機2上啟動centos容器:

docker run -it --name container2 centos /bin/bash

? 分別在兩臺機器上安裝ifconfig,并查看容器的ip,命令是:

[root@695ba390d221 /]# yum search ifconfig [root@695ba390d221 /]# yum install net-tools.x86_64

主機1上的容器ip地址:

主機2上的容器ip:

? 6. 容器間直接通信
好了,現(xiàn)在兩容器可以互ping了
主機1上ping:

主機2上ping:

總結(jié)

以上是生活随笔為你收集整理的Docker容器间通讯,直接路由方式实现网络通讯的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。