flannel 安裝和搭建

Docker CoreOS 網絡拓撲 Git IT優就業 IT優就業 2017-08-29

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 安裝和搭建

啟動 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 上輸出如下:

flannel 安裝和搭建

① 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。

flannel 安裝和搭建

host1 添加了一條路由:目的地址為 flannel 網絡 10.2.0.0/16 的數據包都由 flannel.1 轉發。

flannel 安裝和搭建

host2 輸出類似,主要區別是 host2 的 subnet 為 10.2.17.0/24:

flannel 安裝和搭建

當前環境網絡拓撲如圖所示:

flannel 安裝和搭建

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

相關推薦

推薦中...