利用weave工具實現(xiàn)跨物理主機(jī)組網(wǎng)

Weave簡介

當(dāng)容器分布在多個不同的主機(jī)上時悼嫉,這些容器之間的相互通信變得復(fù)雜起來履怯。容器在不同主機(jī)之間都使用的是自己的私有IP地址回还,不同主機(jī)的容器之間進(jìn)行通訊需要將主機(jī)的端口映射到容器的端口上,而且IP地址需要使用主機(jī)的IP地址叹洲。Weave正是為了解決這個問題而出現(xiàn)的柠硕,它把不同主機(jī)上容器互相連接的網(wǎng)絡(luò)虛擬成一個類似于本地網(wǎng)絡(luò)的網(wǎng)絡(luò)。
如果了解SDN技術(shù)或者部署過OpenStack的網(wǎng)絡(luò)模塊(Neutron)的話运提,這里通過Weave構(gòu)建的網(wǎng)絡(luò)與它們比較類似蝗柔。它是在一個網(wǎng)絡(luò)的基礎(chǔ)上,構(gòu)建了一層由軟件定義的網(wǎng)絡(luò)層民泵,這個網(wǎng)絡(luò)看起來就像是一個本地的局域網(wǎng)癣丧,但是實際上它的底層通過另一個網(wǎng)絡(luò)進(jìn)行通信。這個網(wǎng)絡(luò)可能會比實際物理局域網(wǎng)的可靠性要差一些栈妆,但是從可用性角度來看胁编,它帶來了很大的便利性:可以在位于不同位置的節(jié)點之間通信,而好像它們在一個地方一樣鳞尔。也可以把這種網(wǎng)絡(luò)想象成一個類似于VPN似的東西嬉橙。
weave通過在docker集群的每個主機(jī)上啟動虛擬的路由器,將主機(jī)作為路由器寥假,形成互聯(lián)互通的網(wǎng)絡(luò)拓?fù)涫锌颍诖嘶A(chǔ)上,實現(xiàn)容器的跨主機(jī)通信昧旨。其主機(jī)網(wǎng)絡(luò)拓?fù)鋮⒁娤聢D:


image.png

如上圖所示拾给,在每一個部署Docker的主機(jī)(可能是物理機(jī)也可能是虛擬機(jī))上都部署有一個W(即weave router祥得,它本身也可以以一個容器的形式部署)。

Weave的安裝與啟動

安裝
sudo curl -L git.io/weave -o /usr/local/bin/weave
sudo chmod a+x /usr/local/bin/weave

可以通過以下命令檢驗是否安裝完成

weave version
weave status
啟動
weave launch

之后會pull下來3個鏡像蒋得,分別是

REPOSITORY                              TAG                 IMAGE ID            CREATED             SIZE
weaveworks/weaveexec                    2.4.1               9e84d368c391        2 days ago          151MB
weaveworks/weave                        2.4.1               ff4c735f9ce5        2 days ago          96.6MB
weaveworks/weavedb                      latest              15c78a9b1895        7 weeks ago         698B

還會run一個容器

325677aa3f97        weaveworks/weave:2.4.1   "/home/weave/weaver …"   19 hours ago        Up 19 hours                             weave

還會新啟動一個網(wǎng)絡(luò)

NETWORK ID          NAME                DRIVER              SCOPE
ae3da1032819        weave               weavemesh           local

Weave的部署

1)機(jī)器環(huán)境準(zhǔn)備:(2臺云服務(wù)器)
node-1:119.29.241.15
node-2:134.175.64.74
2)在3臺機(jī)上均啟動一個應(yīng)用容器
由于weave2.0版本里 weave run命令已經(jīng)remove级及,所以此處采取docker run + weave connect的方式
在node-1上啟動容器my-test1

docker run -itd --name=my-test1 
weave attach 192.168.0.2/24 my-test1 // weave detach 192.168.0.2/24 my-test1表示刪除這個綁定
docker exec -ti my-test1 /bin/sh
ifconfig

在config中,可以看到有eth0和weave兩個網(wǎng)橋

eth0      Link encap:Ethernet  HWaddr 02:42:AC:11:00:04
          inet addr:172.17.0.4  Bcast:0.0.0.0  Mask:255.255.0.0
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:40 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0
          RX bytes:2296 (2.2 KiB)  TX bytes:0 (0.0 B)

ethwe     Link encap:Ethernet  HWaddr E2:E9:8E:EC:B2:84
          inet addr:192.168.0.2  Bcast:192.168.0.255  Mask:255.255.255.0
          UP BROADCAST RUNNING MULTICAST  MTU:1376  Metric:1
          RX packets:42 errors:0 dropped:0 overruns:0 frame:0
          TX packets:29 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0
          RX bytes:2618 (2.5 KiB)  TX bytes:1946 (1.9 KiB)

在node-1上啟動容器my-test2额衙,重復(fù)node-1的操作

docker run -itd --name=my-test2
weave attach 192.168.0.3/24 my-test2
docker exec -ti my-test2 /bin/sh
ifconfig

應(yīng)該也可以看到my-test2的網(wǎng)絡(luò)情況
3)容器互聯(lián)
默認(rèn)情況下饮焦,上面在node-1和node-2兩臺宿主機(jī)上創(chuàng)建的2個容器間都是相互ping不通的。需要使用weave connect命令在兩臺weave的路由器之間建立連接窍侧。
在node-1上執(zhí)行

weave connect 134.175.64.74 // weave forget ip則表示斷開這個連接

然后就會發(fā)現(xiàn)县踢,此時位于兩臺不同主機(jī)上的相同子網(wǎng)段內(nèi)的容器之間可以相互ping通了。再在node-1上啟動容器my-test3伟件,綁定ip為192.168.0.8硼啤,在node-2上啟動容器my-test4,綁定ip為192.168.0.10會發(fā)現(xiàn)這四個在同一個子網(wǎng)內(nèi)的容器都是可以相互ping通的斧账。再接著啟動與上面不在同一個子網(wǎng)內(nèi)的容器node-1上啟動容器my-test5谴返,綁定ip為192.168.10.10,node-2上啟動容器my-test6咧织,綁定ip為192.168.10.20嗓袱。會發(fā)現(xiàn)在跨主機(jī)情況下,相同子網(wǎng)內(nèi)的容器是可以相互通信的习绢;但是處于不同子網(wǎng)的兩個容器是不能互聯(lián)的渠抹,盡管這兩個容器在同一個主機(jī)下也是不能通信的!
這樣的好處就是:使用不同子網(wǎng)進(jìn)行容器間的網(wǎng)絡(luò)隔離了闪萄。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末梧却,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子桃煎,更是在濱河造成了極大的恐慌篮幢,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,110評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件为迈,死亡現(xiàn)場離奇詭異三椿,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)葫辐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,443評論 3 395
  • 文/潘曉璐 我一進(jìn)店門搜锰,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人耿战,你說我怎么就攤上這事蛋叼。” “怎么了?”我有些...
    開封第一講書人閱讀 165,474評論 0 356
  • 文/不壞的土叔 我叫張陵狈涮,是天一觀的道長狐胎。 經(jīng)常有香客問我,道長歌馍,這世上最難降的妖魔是什么握巢? 我笑而不...
    開封第一講書人閱讀 58,881評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮松却,結(jié)果婚禮上暴浦,老公的妹妹穿的比我還像新娘。我一直安慰自己晓锻,他們只是感情好歌焦,可當(dāng)我...
    茶點故事閱讀 67,902評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著砚哆,像睡著了一般独撇。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上窟社,一...
    開封第一講書人閱讀 51,698評論 1 305
  • 那天券勺,我揣著相機(jī)與錄音绪钥,去河邊找鬼灿里。 笑死,一個胖子當(dāng)著我的面吹牛程腹,可吹牛的內(nèi)容都是我干的匣吊。 我是一名探鬼主播,決...
    沈念sama閱讀 40,418評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼寸潦,長吁一口氣:“原來是場噩夢啊……” “哼色鸳!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起见转,我...
    開封第一講書人閱讀 39,332評論 0 276
  • 序言:老撾萬榮一對情侶失蹤命雀,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后斩箫,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體吏砂,經(jīng)...
    沈念sama閱讀 45,796評論 1 316
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,968評論 3 337
  • 正文 我和宋清朗相戀三年乘客,在試婚紗的時候發(fā)現(xiàn)自己被綠了狐血。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,110評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡易核,死狀恐怖匈织,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤缀匕,帶...
    沈念sama閱讀 35,792評論 5 346
  • 正文 年R本政府宣布纳决,位于F島的核電站,受9級特大地震影響乡小,放射性物質(zhì)發(fā)生泄漏岳链。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,455評論 3 331
  • 文/蒙蒙 一劲件、第九天 我趴在偏房一處隱蔽的房頂上張望掸哑。 院中可真熱鬧,春花似錦零远、人聲如沸苗分。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,003評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽摔癣。三九已至,卻和暖如春纬向,著一層夾襖步出監(jiān)牢的瞬間择浊,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,130評論 1 272
  • 我被黑心中介騙來泰國打工逾条, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留琢岩,地道東北人。 一個月前我還...
    沈念sama閱讀 48,348評論 3 373
  • 正文 我出身青樓师脂,卻偏偏與公主長得像担孔,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子吃警,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,047評論 2 355

推薦閱讀更多精彩內(nèi)容