1. 程式人生 > >跨主機網絡概述 - 每天5分鐘玩轉 Docker 容器技術(48)

跨主機網絡概述 - 每天5分鐘玩轉 Docker 容器技術(48)

docker 教程 容器

前面已經學習了 Docker 的幾種網絡方案:none、host、bridge 和 joined 容器,它們解決了單個 Docker Host 內容器通信的問題。本章的重點則是討論跨主機容器間通信的方案。

技術分享

跨主機網絡方案包括:

  1. docker 原生的 overlay 和 macvlan。

  2. 第三方方案:常用的包括 flannel、weave 和 calico。

docker 網絡是一個非常活躍的技術領域,不斷有新的方案開發出來,那麽要問個非常重要的問題了:

如此眾多的方案是如何與 docker 集成在一起的?

答案是:libnetwork 以及 CNM。

libnetwork & CNM

libnetwork 是 docker 容器網絡庫,最核心的內容是其定義的 Container Network Model (CNM),這個模型對容器網絡進行了抽象,由以下三類組件組成:

Sandbox

Sandbox 是容器的網絡棧,包含容器的 interface、路由表和 DNS 設置。 Linux Network Namespace 是 Sandbox 的標準實現。Sandbox 可以包含來自不同 Network 的 Endpoint。

Endpoint

Endpoint 的作用是將 Sandbox 接入 Network。Endpoint 的典型實現是 veth pair,後面我們會舉例。一個 Endpoint 只能屬於一個網絡,也只能屬於一個 Sandbox。

Network

Network 包含一組 Endpoint,同一 Network 的 Endpoint 可以直接通信。Network 的實現可以是 Linux Bridge、VLAN 等。

下面是 CNM 的示例:

技術分享

如圖所示兩個容器,一個容器一個 Sandbox,每個 Sandbox 都有一個 Endpoint 連接到 Network 1,第二個 Sandbox 還有一個 Endpoint 將其接入 Network 2.

libnetwork CNM 定義了 docker 容器的網絡模型,按照該模型開發出的 driver 就能與 docker daemon 協同工作,實現容器網絡。docker 原生的 driver 包括 none、bridge、overlay 和 macvlan,第三方 driver 包括 flannel、weave、calico 等。

技術分享

下面我們以 docker bridge driver 為例討論 libnetwork CNM 是如何被實現的。

技術分享

這是前面我們討論過的一個容器環境:

  1. 兩個 Network:默認網絡 “bridge” 和自定義網絡 “my_net2”。實現方式是 Linux Bridge:“docker0” 和 “br-5d863e9f78b6”。

  2. 三個 Enpoint,由 veth pair 實現,一端(vethxxx)掛在 Linux Bridge 上,另一端(eth0)掛在容器內。

  3. 三個 Sandbox,由 Network Namespace 實現,每個容器有自己的 Sanbox。

接下來我們將詳細討論各種跨主機網絡方案,首先學習 Overlay。

技術分享

跨主機網絡概述 - 每天5分鐘玩轉 Docker 容器技術(48)