什么是服務(wù)

微服務(wù)體系結(jié)構(gòu)(有時(shí)也稱微服務(wù))是一種架構(gòu)風(fēng)格冯吓,它將應(yīng)用根據(jù)業(yè)務(wù)邏輯拆分成一系列功能不同并且相互協(xié)同合作的一系列服務(wù),這些服務(wù)共同組成一個(gè)完成的應(yīng)用令漂。這使持續(xù)交付/部署一個(gè)大而復(fù)雜的應(yīng)用成為可能膝昆。微服務(wù)具有更好的伸縮性、容錯(cuò)性叠必,實(shí)驗(yàn)新技術(shù)和迭代新的技術(shù)棧也更加方便荚孵。

在使用微服務(wù)時(shí),最關(guān)鍵的體系結(jié)構(gòu)決策是識(shí)別和設(shè)計(jì)服務(wù)纬朝,并確定這些服務(wù)之間如何協(xié)作收叶,相比之下,技術(shù)相關(guān)的問(wèn)題共苛,例如docker判没、k8s等就顯得無(wú)足輕重了。

服務(wù)的關(guān)鍵屬性

一個(gè)服務(wù)具有以下關(guān)鍵屬性:

  • 高可維護(hù)性和高可測(cè)試性-支持快速頻繁地開發(fā)和部署

  • 與其他服務(wù)輕耦合-服務(wù)的ower在大部分時(shí)間應(yīng)該能獨(dú)立工作在自己的服務(wù)上俄讹,不受其他服務(wù)的影響,也不影響其他服務(wù)

  • 可獨(dú)立部署-團(tuán)隊(duì)能夠獨(dú)立部署自己的服務(wù)绕德,無(wú)需和其他團(tuán)隊(duì)進(jìn)行協(xié)調(diào)

  • 小團(tuán)隊(duì)開發(fā)-通過(guò)避免大團(tuán)隊(duì)的高交流成本來(lái)獲得高生產(chǎn)力

服務(wù)的結(jié)構(gòu)

下圖展示了一個(gè)六邊形的服務(wù)結(jié)構(gòu)患膛,服務(wù)的核心是業(yè)務(wù)邏輯,業(yè)務(wù)邏輯被與之相關(guān)聯(lián)的服務(wù)和應(yīng)用所包圍耻蛇。

服務(wù)結(jié)構(gòu)

具體來(lái)看一下每個(gè)結(jié)構(gòu):

服務(wù)具有API

從使用者的角度來(lái)看踪蹬,服務(wù)唯一重要的是它的API。服務(wù)API由操作和發(fā)布的事件組成臣咖。

操作

有兩種類型的操作:命令和查詢跃捣。命令是一種改變數(shù)據(jù)的操作。查詢是檢索數(shù)據(jù)的命令

使用同步協(xié)議(如REST或gRPC)和異步消息傳遞的組合來(lái)調(diào)用服務(wù)操作夺蛇。在為外部客戶端(如移動(dòng)應(yīng)用程序和單頁(yè)面應(yīng)用程序)實(shí)現(xiàn)api時(shí)疚漆,同步協(xié)議(尤其是REST)特別有用。

事件

服務(wù)通常發(fā)布事件。事件通常是DDD域事件娶聘,由聚合在創(chuàng)建闻镶、更新或刪除時(shí)發(fā)出。服務(wù)將事件發(fā)布到消息代理實(shí)現(xiàn)的消息通道丸升。例如铆农,Eventuate Tram框架支持發(fā)布事件到Apache Kafka, ActiveMQ和RabbitMQ。

業(yè)務(wù)邏輯

服務(wù)的核心和存在的原因狡耻。它實(shí)現(xiàn)API的操作和發(fā)布事件墩剖。業(yè)務(wù)邏輯調(diào)用其他服務(wù)的操作并訂閱它們的事件。它將數(shù)據(jù)保存在服務(wù)的數(shù)據(jù)庫(kù)中夷狰。

服務(wù)可能和其他服務(wù)協(xié)作

當(dāng)服務(wù)協(xié)作時(shí)岭皂,是通過(guò)api而不是數(shù)據(jù)庫(kù)。一個(gè)服務(wù)可以調(diào)用另一個(gè)服務(wù)的操作孵淘,服務(wù)還可以訂閱另一個(gè)服務(wù)發(fā)布的事件蒲障。

服務(wù)的數(shù)據(jù)庫(kù)是私有的

一個(gè)服務(wù)通常有一個(gè)數(shù)據(jù)庫(kù),用于存儲(chǔ)它的數(shù)據(jù)瘫证,有時(shí)也存儲(chǔ)從其他服務(wù)復(fù)制的數(shù)據(jù)揉阎,為了確保松耦合,服務(wù)共享數(shù)據(jù)庫(kù)表通常不是一個(gè)好主意背捌。相反毙籽,服務(wù)只能通過(guò)它們的api進(jìn)行通信。

個(gè)人博客

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末毡庆,一起剝皮案震驚了整個(gè)濱河市坑赡,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌么抗,老刑警劉巖毅否,帶你破解...
    沈念sama閱讀 216,843評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異蝇刀,居然都是意外死亡螟加,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,538評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門吞琐,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)捆探,“玉大人,你說(shuō)我怎么就攤上這事站粟∈蛲迹” “怎么了?”我有些...
    開封第一講書人閱讀 163,187評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵奴烙,是天一觀的道長(zhǎng)助被。 經(jīng)常有香客問(wèn)我剖张,道長(zhǎng),這世上最難降的妖魔是什么恰起? 我笑而不...
    開封第一講書人閱讀 58,264評(píng)論 1 292
  • 正文 為了忘掉前任修械,我火速辦了婚禮,結(jié)果婚禮上检盼,老公的妹妹穿的比我還像新娘肯污。我一直安慰自己,他們只是感情好吨枉,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,289評(píng)論 6 390
  • 文/花漫 我一把揭開白布蹦渣。 她就那樣靜靜地躺著,像睡著了一般貌亭。 火紅的嫁衣襯著肌膚如雪柬唯。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,231評(píng)論 1 299
  • 那天圃庭,我揣著相機(jī)與錄音锄奢,去河邊找鬼。 笑死剧腻,一個(gè)胖子當(dāng)著我的面吹牛拘央,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播书在,決...
    沈念sama閱讀 40,116評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼灰伟,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了儒旬?” 一聲冷哼從身側(cè)響起栏账,我...
    開封第一講書人閱讀 38,945評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎栈源,沒(méi)想到半個(gè)月后挡爵,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,367評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡甚垦,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,581評(píng)論 2 333
  • 正文 我和宋清朗相戀三年茶鹃,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片制轰。...
    茶點(diǎn)故事閱讀 39,754評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡前计,死狀恐怖胞谭,靈堂內(nèi)的尸體忽然破棺而出垃杖,到底是詐尸還是另有隱情,我是刑警寧澤丈屹,帶...
    沈念sama閱讀 35,458評(píng)論 5 344
  • 正文 年R本政府宣布调俘,位于F島的核電站伶棒,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏彩库。R本人自食惡果不足惜肤无,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,068評(píng)論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望骇钦。 院中可真熱鬧宛渐,春花似錦、人聲如沸眯搭。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,692評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)鳞仙。三九已至寇蚊,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間棍好,已是汗流浹背仗岸。 一陣腳步聲響...
    開封第一講書人閱讀 32,842評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留借笙,地道東北人扒怖。 一個(gè)月前我還...
    沈念sama閱讀 47,797評(píng)論 2 369
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像提澎,于是被迫代替她去往敵國(guó)和親姚垃。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,654評(píng)論 2 354

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