build flannel
flannel 沒有現成的執行文件可用,必須自己 build,最可靠的方法是在 Docker 容器中 build。不過用於做 build 的 docker 鏡像託管在 gcr.io,國內可能無法直接訪問,為方便大家,我把它 mirror 到了 docker hub,構建步驟如下:
1、下載並重命名 image。
docker pull cloudman6/kube-cross:v1.6.2-2
docker tag cloudman6/kube-cross:v1.6.2-2 gcr.io/google_containers/kube-cross:v1.6.2-2
2、下載 flannel 源碼。
git clone https://github.com/coreos/flannel.git
3、開始構建。
cd flannel
make dist/flanneld-amd64
4、將 flanneld 執行文件拷貝到 host1 和 host2。
scp dist/flanneld-amd64 192.168.56.104:/usr/local/bin/flanneld
scp dist/flanneld-amd64 192.168.56.105:/usr/local/bin/flanneld
4、將 flannel 網絡的配置信息保存到 etcd
先將配置信息寫到文件 flannel-config.json 中,內容為:
{
"Network": "10.2.0.0/16",
"SubnetLen": 24,
"Backend": {
"Type": "vxlan"
}
}
Network 定義該網絡的 IP 池為 10.2.0.0/16。
SubnetLen 指定每個主機分配到的 subnet 大小為 24 位,即10.2.X.0/24。
Backend 為 vxlan,即主機間通過 vxlan 通信,後面我們還會討論host-gw。
將配置存入 etcd:
etcdctl --endpoints=192.168.56.101:2379 set /docker-test/network/config < flannel-config.json
/docker-test/network/config 是此 etcd 數據項的 key,其 value 為 flannel-config.json 的內容。key 可以任意指定,這個 key 後面會作為 flanneld 的一個啟動參數。執行 etcdctl get 確保設置成功。
啟動 flannel
在 host1 和 host2 上執行如下命令:
flanneld -etcd-endpoints=http://192.168.56.101:2379 -iface=enp0s8 -etcd-prefix=/docker-test/network
-etcd-endpoints 指定 etcd url。
-iface 指定主機間數據傳輸使用的 interface。
-etcd-prefix 指定 etcd 存放 flannel 網絡配置信息的 key。
host1 上輸出如下:
① enp0s8 被選作與外部主機通信的 interface。
② 識別 flannel 網絡池 10.2.0.0/16。
③ 分配的 subnet 為 10.2.40.0/24。
flanneld 啟動後,host1 內部網絡會發生一些變化:
一個新的 interface flannel.1 被創建,而且配置上 subnet 的第一個 IP 10.2.40.0。
host1 添加了一條路由:目的地址為 flannel 網絡 10.2.0.0/16 的數據包都由 flannel.1 轉發。
host2 輸出類似,主要區別是 host2 的 subnet 為 10.2.17.0/24:
當前環境網絡拓撲如圖所示:
flannel 已經就緒。
中公優就業IT培訓,總有你想學的:http://xue.ujiuye.com
勤工儉學計劃,0元學IT!
http://www.ujiuye.com/zt/qgjx/?wt.bd=mmxtt
找工作太難?好漢,讓我助你一臂之力!
http://www.ujiuye.com/zt/jyfc/?wt.bd=mmxtt