docker swarm(二):Ingress Routing Mesh的理解與應(yīng)用

概述

Routing Mesh是docker swarm提供的確保service在多節(jié)點(diǎn)網(wǎng)絡(luò)上可用的集群網(wǎng)絡(luò)機(jī)制烫映。其分為兩類:

  • Internal Routing Mesh
  • Ingress Routing Mesh

本文先介紹Ingress Routing Mesh沼本。它提供以下服務(wù):如果service有綁定發(fā)布接口,則此服務(wù)可以通過任意Swarm節(jié)點(diǎn)的此端口進(jìn)行訪問锭沟。并實(shí)現(xiàn)負(fù)載均衡抽兆。

Ingress Routing Mesh實(shí)驗(yàn)

首先搭建一個(gè)1 manager, 1 worker的docker swarm。詳見《docker swarm(一): 入門冈钦,搭建一個(gè)簡單的swarm集群》郊丛。假設(shè)環(huán)境如下:

$ docker node ls
ID                            HOSTNAME            STATUS              AVAILABILITY        MANAGER STATUS      ENGINE VERSION
eak5lww1jjhgwbdm0b97dh8gd *   ubuntu              Ready               Active              Leader              19.03.5
y34vyxwzlumiyzr67sksi44gh     ubuntu-2            Ready               Active                                  19.03.5

我們使用nginx來做實(shí)驗(yàn),下載nginx的image瞧筛。

$ docker image pull nginx

創(chuàng)建一個(gè)包含兩個(gè)task的service。--publish定義了docker swarm對外提供服務(wù)的端口映射导盅。在下例中较幌,docker swarm對外在8080端口提供服務(wù),中繼了nginx container的80端口的報(bào)文白翻。

$ docker service create \
  --name my-web \
  --publish published=8080,target=80 \
  --replicas 2 \
  nginx

檢查一下運(yùn)行狀態(tài)乍炉,在兩個(gè)節(jié)點(diǎn)上分別運(yùn)行了一個(gè)任務(wù)。

$ docker service ps my-web
ID                  NAME                IMAGE               NODE                DESIRED STATE       CURRENT STATE            ERROR               PORTS
vqp43b7wqsvu        my-web.1            nginx:latest        ubuntu-2            Running             Running 29 seconds ago                       
a7nbr7chvldm        my-web.2            nginx:latest        ubuntu              Running             Running 24 seconds ago 

訪問swarm nodes的8080端口(在本例中是
http://192.168.154.135:8080/和
http://192.168.154.136:8080/)滤馍,都可以看到nginx的初始頁面岛琼。

nginx初始化頁

下面通過docker service scale把my-web service的任務(wù)數(shù)改為1。

spencer@ubuntu:~$ docker service scale my-web=1
my-web scaled to 1
overall progress: 1 out of 1 tasks 
1/1: running   [==================================================>] 
verify: Service converged 
spencer@ubuntu:~$ 
spencer@ubuntu:~$ docker service ps my-web
ID                  NAME                IMAGE               NODE                DESIRED STATE       CURRENT STATE            ERROR               PORTS
vqp43b7wqsvu        my-web.1            nginx:latest        ubuntu-2            Running             Running 27 minutes ago                 

現(xiàn)在巢株,只在worker節(jié)點(diǎn)(192.168.154.136)上運(yùn)行槐瑞。

關(guān)鍵的來了,雖然現(xiàn)在service僅在worker節(jié)點(diǎn)上運(yùn)行阁苞,但我們訪問manager和worker節(jié)點(diǎn)的8080端口困檩,都能成功訪問nginx祠挫。

nginx初始化頁

原理分析

Docker Swarm內(nèi)置一個(gè)負(fù)載均衡器(Balancer),它會(huì)監(jiān)聽任意一個(gè)節(jié)點(diǎn)上的published端口悼沿,將端口上的請求中繼到容器中等舔。

實(shí)際訪問的容器,不一定與用戶訪問的IP屬于同一節(jié)點(diǎn)糟趾,可能在另一個(gè)節(jié)點(diǎn)上慌植。

Ingress Routing Mesh

在node與node之間,docker swarm建立overlay網(wǎng)絡(luò)(名字為ingress)义郑,用于容器與容器之間的通信涤浇。

Routing Mesh就是基于ingress overlay網(wǎng)絡(luò),實(shí)現(xiàn)的節(jié)點(diǎn)間的報(bào)文轉(zhuǎn)發(fā)魔慷。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末只锭,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子院尔,更是在濱河造成了極大的恐慌蜻展,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,651評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件邀摆,死亡現(xiàn)場離奇詭異纵顾,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)栋盹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評論 3 392
  • 文/潘曉璐 我一進(jìn)店門施逾,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人例获,你說我怎么就攤上這事汉额。” “怎么了榨汤?”我有些...
    開封第一講書人閱讀 162,931評論 0 353
  • 文/不壞的土叔 我叫張陵蠕搜,是天一觀的道長。 經(jīng)常有香客問我收壕,道長妓灌,這世上最難降的妖魔是什么蜜宪? 我笑而不...
    開封第一講書人閱讀 58,218評論 1 292
  • 正文 為了忘掉前任虫埂,我火速辦了婚禮,結(jié)果婚禮上圃验,老公的妹妹穿的比我還像新娘掉伏。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,234評論 6 388
  • 文/花漫 我一把揭開白布岖免。 她就那樣靜靜地躺著岳颇,像睡著了一般。 火紅的嫁衣襯著肌膚如雪颅湘。 梳的紋絲不亂的頭發(fā)上话侧,一...
    開封第一講書人閱讀 51,198評論 1 299
  • 那天,我揣著相機(jī)與錄音闯参,去河邊找鬼瞻鹏。 笑死,一個(gè)胖子當(dāng)著我的面吹牛鹿寨,可吹牛的內(nèi)容都是我干的新博。 我是一名探鬼主播,決...
    沈念sama閱讀 40,084評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼脚草,長吁一口氣:“原來是場噩夢啊……” “哼赫悄!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起馏慨,我...
    開封第一講書人閱讀 38,926評論 0 274
  • 序言:老撾萬榮一對情侶失蹤埂淮,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后写隶,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體倔撞,經(jīng)...
    沈念sama閱讀 45,341評論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,563評論 2 333
  • 正文 我和宋清朗相戀三年慕趴,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了痪蝇。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,731評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡冕房,死狀恐怖躏啰,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情毒费,我是刑警寧澤丙唧,帶...
    沈念sama閱讀 35,430評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站觅玻,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏培漏。R本人自食惡果不足惜溪厘,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,036評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望牌柄。 院中可真熱鬧畸悬,春花似錦、人聲如沸珊佣。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至冷冗,卻和暖如春守屉,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蒿辙。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評論 1 269
  • 我被黑心中介騙來泰國打工拇泛, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人思灌。 一個(gè)月前我還...
    沈念sama閱讀 47,743評論 2 368
  • 正文 我出身青樓俺叭,卻偏偏與公主長得像,于是被迫代替她去往敵國和親泰偿。 傳聞我的和親對象是個(gè)殘疾皇子熄守,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,629評論 2 354

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