flannel 的連通與隔離 - 每天5分鍾玩轉 Docker 容器技術(61)


上一節我們在 flannel 網絡中部署了容器,本節討論 flannel 的連通和隔離特性。

flannel 網絡連通性

測試 bbox1 和 bbxo2 的連通性:

bbox1 能夠 ping 到位於不同 subnet 的 bbox2,通過 traceroute 分析一下 bbox1 到 bbox2 的路徑。

  1. bbox1 與 bbox2 不是一個 subnet,數據包發送給默認網關 10.2.40.1(docker0)。

  2. 根據 host1 的路由表(下圖),數據包會發給 flannel.1。

  3. flannel.1 將數據包封裝成 VxLAN,通過 enp0s8 發送給 host2。

  4. host2 收到包解封裝,發現數據包目的地址為 10.2.17.2,根據路由表(下圖)將數據包發送給 flannel.1,並通過 docker0 到達 bbox2。

數據流向如圖所示:

另外,flannel 是沒有 DNS 服務的,容器無法通過 hostname 通信。

flannel 網絡隔離

flannel 為每個主機分配了獨立的 subnet,但 flannel.1 將這些 subnet 連接起來了,相互之間可以路由。本質上,flannel 將各主機上相互獨立的 docker0 容器網絡組成了一個互通的大網絡,實現了容器跨主機通信。flannel 沒有提供隔離。

flannel 與外網連通性

因為 flannel 網絡利用的是默認的 bridge 網絡,所以容器與外網的連通方式與 bridge 網絡一樣,即:

  1. 容器通過 docker0 NAT 訪問外網

  2. 通過主機端口映射,外網可以訪問容器

詳細討論可參考前面 bridge 網絡相關章節。

以上是 flannel vxlan 的相關知識點,下一節我們討論 flannel host-gw backend。

二維碼+指紋.png


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM