flannel 是 CoreOS 開發的容器網絡解決方案。flannel 爲每一個 host 分配一個 subnet,容器今後 subnet 中分配 IP,這些 IP 能夠在 host 間路由,容器間無需 NAT 和 port mapping 就能夠跨主機通訊。linux
每一個 subnet 都是從一個更大的 IP 池中劃分的,flannel 會在每一個主機上運行一個叫 flanneld 的 agent,其職責就是從池子 中分配 subnet。爲了在各個主機間共享信息,flannel 用 etcd(與 consul 相似的 key-value 分佈式數據庫)存放網絡配置、已分配的 subnet、host 的 IP 等信息。git
數據包如何在主機間轉發是由 backend 實現的。flannel 提供了多種 backend,最經常使用的有 vxlan 和 host-gw,咱們將在本章討論這兩種 backend。其餘 backend 請參考 https://github.com/coreos/flannel。接下來咱們就開始實踐 flannel。github
本章實驗環境如圖所示:數據庫
flannel<etcd>flannelubuntu
etcd 部署在 10.0.0.20,host1 和 host2 上運行 flanneld,首先安裝配置 etcd。網絡
在 10.0.0.20上運行以下腳本:app
ETCD_VER=v2.3.7 DOWNLOAD_URL=https://github.com/coreos/etcd/releases/download curl -L ${DOWNLOAD_URL}/${ETCD_VER}/etcd-${ETCD_VER}-linux-amd64.tar.gz -o /tmp/etcd-${ETCD_VER}-linux-amd64.tar.gz mkdir -p /tmp/test-etcd && tar xzvf /tmp/etcd-${ETCD_VER}-linux-amd64.tar.gz -C /tmp/test-etcd --strip-components=1 cp /tmp/test-etcd/etcd* /usr/local/bin/
該腳本從 github 上下載 etcd 的可執行文件並保存到 /usr/local/bin/,啓動 etcd 並打開 2379 監聽端口。curl
etcd -listen-client-urls http://10.0.0.20:2379 -advertise-client-urls http://10.0.0.20:2379
測試 etcd 是否可用:分佈式
root@ubuntu-01:/tmp/test-etcd# etcdctl --endpoints=10.0.0.20:2379 set foo "bar" bar root@ubuntu-01:/tmp/test-etcd# etcdctl --endpoints=10.0.0.20:2379 get foo bar root@ubuntu-01:/tmp/test-etcd#