微服務(wù)架構(gòu)的設(shè)計(jì)模式

聚合器微服務(wù)設(shè)計(jì)模式

這是一種最常用也最簡單的設(shè)計(jì)模式堤结,如下圖所示:

聚合器調(diào)用多個(gè)服務(wù)實(shí)現(xiàn)應(yīng)用程序所需的功能绎狭。它可以是一個(gè)簡單的Web頁面灌侣,將檢索到的數(shù)據(jù)進(jìn)行處理展示治专。它也可以是一個(gè)更高層次的組合微服務(wù)卖陵,對(duì)檢索到的數(shù)據(jù)增加業(yè)務(wù)邏輯后進(jìn)一步發(fā)布成一個(gè)新的微服務(wù),這符合DRY原則张峰。另外泪蔫,每個(gè)服務(wù)都有自己的緩存和數(shù)據(jù)庫。如果聚合器是一個(gè)組合服務(wù)喘批,那么它也有自己的緩存和數(shù)據(jù)庫撩荣。聚合器可以沿X軸和Z軸獨(dú)立擴(kuò)展铣揉。

代理微服務(wù)設(shè)計(jì)模式

這是聚合器模式的一個(gè)變種,如下圖所示:

在這種情況下婿滓,客戶端并不聚合數(shù)據(jù)老速,但會(huì)根據(jù)業(yè)務(wù)需求的差別調(diào)用不同的微服務(wù)。代理可以僅僅委派請求凸主,也可以進(jìn)行數(shù)據(jù)轉(zhuǎn)換工作橘券。

鏈?zhǔn)轿⒎?wù)設(shè)計(jì)模式

這種模式在接收到請求后會(huì)產(chǎn)生一個(gè)經(jīng)過合并的響應(yīng),如下圖所示:

在這種情況下卿吐,服務(wù)A接收到請求后會(huì)與服務(wù)B進(jìn)行通信旁舰,類似地,服務(wù)B會(huì)同服務(wù)C進(jìn)行通信嗡官。所有服務(wù)都使用同步消息傳遞箭窜。在整個(gè)鏈?zhǔn)秸{(diào)用完成之前,客戶端會(huì)一直阻塞衍腥。因此磺樱,服務(wù)調(diào)用鏈不宜過長,以免客戶端長時(shí)間等待婆咸。

分支微服務(wù)設(shè)計(jì)模式

這種模式是聚合器模式的擴(kuò)展竹捉,允許同時(shí)調(diào)用兩個(gè)微服務(wù)鏈,如下圖所示:

數(shù)據(jù)共享微服務(wù)設(shè)計(jì)模式

自治是微服務(wù)的設(shè)計(jì)原則之一尚骄,就是說微服務(wù)是全棧式服務(wù)块差。但在重構(gòu)現(xiàn)有的“單體應(yīng)用(monolithic
application)”時(shí),SQL數(shù)據(jù)庫反規(guī)范化可能會(huì)導(dǎo)致數(shù)據(jù)重復(fù)和不一致倔丈。因此憨闰,在單體應(yīng)用到微服務(wù)架構(gòu)的過渡階段,可以使用這種設(shè)計(jì)模式需五,如下圖所示:

在這種情況下鹉动,部分微服務(wù)可能會(huì)共享緩存和數(shù)據(jù)庫存儲(chǔ)。不過宏邮,這只有在兩個(gè)服務(wù)之間存在強(qiáng)耦合關(guān)系時(shí)才可以泽示。對(duì)于基于微服務(wù)的新建應(yīng)用程序而言,這是一種反模式蜀铲。

異步消息傳遞微服務(wù)設(shè)計(jì)模式

雖然REST設(shè)計(jì)模式非常流行边琉,但它是同步的属百,會(huì)造成阻塞记劝。因此部分基于微服務(wù)的架構(gòu)可能會(huì)選擇使用消息隊(duì)列代替REST請求/響應(yīng),如下圖所示:

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末族扰,一起剝皮案震驚了整個(gè)濱河市厌丑,隨后出現(xiàn)的幾起案子定欧,更是在濱河造成了極大的恐慌,老刑警劉巖怒竿,帶你破解...
    沈念sama閱讀 216,470評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件砍鸠,死亡現(xiàn)場離奇詭異,居然都是意外死亡耕驰,警方通過查閱死者的電腦和手機(jī)爷辱,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來朦肘,“玉大人饭弓,你說我怎么就攤上這事∶娇伲” “怎么了弟断?”我有些...
    開封第一講書人閱讀 162,577評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長趴生。 經(jīng)常有香客問我阀趴,道長,這世上最難降的妖魔是什么苍匆? 我笑而不...
    開封第一講書人閱讀 58,176評(píng)論 1 292
  • 正文 為了忘掉前任刘急,我火速辦了婚禮,結(jié)果婚禮上锉桑,老公的妹妹穿的比我還像新娘排霉。我一直安慰自己,他們只是感情好民轴,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,189評(píng)論 6 388
  • 文/花漫 我一把揭開白布攻柠。 她就那樣靜靜地躺著,像睡著了一般后裸。 火紅的嫁衣襯著肌膚如雪仅仆。 梳的紋絲不亂的頭發(fā)上蜘矢,一...
    開封第一講書人閱讀 51,155評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼归露。 笑死,一個(gè)胖子當(dāng)著我的面吹牛移国,可吹牛的內(nèi)容都是我干的蛤育。 我是一名探鬼主播,決...
    沈念sama閱讀 40,041評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼扶檐,長吁一口氣:“原來是場噩夢啊……” “哼凶杖!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起款筑,我...
    開封第一講書人閱讀 38,903評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤智蝠,失蹤者是張志新(化名)和其女友劉穎腾么,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體杈湾,經(jīng)...
    沈念sama閱讀 45,319評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡解虱,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,539評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了漆撞。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片殴泰。...
    茶點(diǎn)故事閱讀 39,703評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖浮驳,靈堂內(nèi)的尸體忽然破棺而出艰匙,到底是詐尸還是另有隱情,我是刑警寧澤抹恳,帶...
    沈念sama閱讀 35,417評(píng)論 5 343
  • 正文 年R本政府宣布员凝,位于F島的核電站,受9級(jí)特大地震影響奋献,放射性物質(zhì)發(fā)生泄漏健霹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,013評(píng)論 3 325
  • 文/蒙蒙 一瓶蚂、第九天 我趴在偏房一處隱蔽的房頂上張望糖埋。 院中可真熱鬧,春花似錦窃这、人聲如沸瞳别。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽祟敛。三九已至,卻和暖如春兆解,著一層夾襖步出監(jiān)牢的瞬間馆铁,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評(píng)論 1 269
  • 我被黑心中介騙來泰國打工锅睛, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留埠巨,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,711評(píng)論 2 368
  • 正文 我出身青樓现拒,卻偏偏與公主長得像辣垒,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子印蔬,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,601評(píng)論 2 353

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

  • 前不久勋桶,Java Code Geeks發(fā)表了一篇文章,分析單體應(yīng)用與微服務(wù)的優(yōu)缺點(diǎn)。近日哥遮,該網(wǎng)站又發(fā)表了一篇文章,...
    weiweicsdn閱讀 1,163評(píng)論 0 6
  • 摘要:本文中陵究,我們將進(jìn)一步理解微服務(wù)架構(gòu)的核心要點(diǎn)和實(shí)現(xiàn)原理眠饮,為讀者的實(shí)踐提供微服務(wù)的設(shè)計(jì)模式,以期讓微服務(wù)在讀者...
    Java架構(gòu)師Carl閱讀 5,776評(píng)論 0 20
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理铜邮,服務(wù)發(fā)現(xiàn)仪召,斷路器,智...
    卡卡羅2017閱讀 134,651評(píng)論 18 139
  • 1. 微服務(wù)架構(gòu)介紹 1.1 什么是微服務(wù)架構(gòu)松蒜? 形像一點(diǎn)來說扔茅,微服務(wù)架構(gòu)就像搭積木,每個(gè)微服務(wù)都是一個(gè)零件秸苗,并使...
    靜修佛緣閱讀 6,641評(píng)論 0 39
  • 最近因業(yè)務(wù)需要惊楼,小拾君深入學(xué)習(xí)了一下微服務(wù)架構(gòu)相關(guān)的技術(shù)玖瘸,跟大家分享一下。本文并不會(huì)涉及太多晦澀難懂的技術(shù)術(shù)語以及...
    每日一拾閱讀 7,471評(píng)論 0 28