精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

從單體式架構遷移到微服務架構:三個策略敘述

開發 架構
遷移單體式應用到微服務架構意味著一系列現代化過程,有點像這幾代開發者一直在做的事情,實時上,當遷移時,我們可以重用一些想法。

 遷移到微服務綜述

遷移單體式應用到微服務架構意味著一系列現代化過程,有點像這幾代開發者一直在做的事情,實時上,當遷移時,我們可以重用一些想法。

[[277795]]

一個策略是:不要大規模(big bang)重寫代碼(只有當你承擔重建一套全新基于微服務的應用時候可以采用重寫這種方法)。重寫代碼聽起來很不錯,但實際上充滿了風險最終可能會失敗,就如 Martin Fowler 所說:“the only thing a Big Bang rewrite guarantees is a Big Bang!”

相反,應該采取逐步遷移單體式應用的策略,通過逐步生成微服務新應用,與舊的單體式應用集成,隨著時間推移,單體式應用在整個架構中比例逐漸下降直到消失或者成為微服務架構一部分。這個策略有點像在高速路上限速到 70 邁對車做維護,盡管有挑戰,但是比起重寫的風險小很多。

Martin Fowler 將這種現代化策略成為絞殺(Strangler)應用,名字來源于雨林中的絞殺藤(strangler vine),也叫絞殺榕 (strangler fig)。絞殺藤為了爬到森林頂端都要纏繞著大叔生長,一段時間后,樹死了,留下樹形藤。這種應用也使用同一種模式,圍繞著傳統應用開發了新型微服務應用,傳統應用會漸漸退出舞臺。

我們來看看其他可行策略。

策略 1——停止挖掘

Law of Holes 是說當自己進洞就應該停止挖掘。對于單體式應用不可管理時這是最佳建議。換句話說,應該停止讓單體式應用繼續變大,也就是說當開發新功能時不應該為舊單體應用添加新代碼,最佳方法應該是將新功能開發成獨立微服務。如下圖所示:

 

從單體式架構遷移到微服務架構:三個策略<span><span><span><i style=完美敘述" src="http://p9.pstatp.com/large/pgc-image/06d58a621e994a15a94749ea4c66e058" _fcksavedurl="http://p9.pstatp.com/large/pgc-image/06d58a621e994a15a94749ea4c66e058" _fcksavedurl="http://p9.pstatp.com/large/pgc-image/06d58a621e994a15a94749ea4c66e058" width="640" height="541">

 

除了新服務和傳統應用,還有兩個模塊,其一是請求路由器,負責處理入口(http)請求,有點像之前提到的 API 網關。路由器將新功能請求發送給新開發的服務,而將傳統請求還發給單體式應用。

另外一個是膠水代碼(glue code),將微服務和單體應用集成起來,微服務很少能獨立存在,經常會訪問單體應用的數據。膠水代碼,可能在單體應用或者為服務或者二者兼而有之,負責數據整合。微服務通過膠水代碼從單體應用中讀寫數據。​

微服務有三種方式訪問單體應用數據:

換氣單體應用提供的遠程 API

直接訪問單體應用數據庫

自己維護一份從單體應用中同步的數據

膠水代碼也被稱為容災層(anti-corruption layer),這是因為膠水代碼保護微服務全新域模型免受傳統單體應用域模型污染。膠水代碼在這兩種模型間提供翻譯功能。術語 anti-corruption layer 第一次出現在 Eric Evans 撰寫的必讀書 Domain Driven Design,隨后就被提煉為一篇白皮書。開發容災層可能有點不是很重要,但卻是避免單體式泥潭的必要部分。

將新功能以輕量級微服務方式實現由很多優點,例如可以阻止單體應用變的更加無法管理。微服務本身可以開發、部署和獨立擴展。采用微服務架構會給開發者帶來不同的切身感受。

然而,這方法并不解決任何單體式本身問題,為了解決單體式本身問題必須深入單體應用​做出改變。我們來看看這么做的策略。

策略 2——將前端和后端分離

減小單體式應用復雜度的策略是講表現層和業務邏輯、數據訪問層分開。典型的企業應用至少有三個不同元素構成:

  1. 表現層——處理 HTTP 請求,要么響應一個 RESTAPI 請求,要么是提供一個基于 HTML 的圖形接口。對于一個復雜用戶接口應用,表現層經常是代碼重要的部分。
  2. 業務邏輯層——完成業務邏輯的應用核心。
  3. 數據訪問層——訪問基礎元素,例如數據庫和消息代理。

在表現層與業務數據訪問層之間有清晰的隔離。業務層有由若干方面組成的粗粒度(coarse-grained)的 API,內部包含了業務邏輯元素。API 是可以將單體業務分割成兩個更小應用的天然邊界,其中一個應用是表現層,另外一個是業務和數據訪問邏輯。分割后,表現邏輯應用遠程調用業務邏輯應用,下圖表示遷移前后架構不同:​

 

從單體式架構遷移到微服務架構:三個策略<span><span><span><i style=完美敘述" src="http://p1.pstatp.com/large/pgc-image/ce2dd2e1adaa4966b3ed87f1b07a15dd" _fcksavedurl="http://p1.pstatp.com/large/pgc-image/ce2dd2e1adaa4966b3ed87f1b07a15dd" _fcksavedurl="http://p1.pstatp.com/large/pgc-image/ce2dd2e1adaa4966b3ed87f1b07a15dd" width="640" height="388">

 

單體應用這么分割有兩個好處,其一使得應用兩部分開發、部署和擴展各自獨立,特別地,允許表現層開發者在用戶界面上快速選擇,進行 A/B 測試;其二,使得一些遠程 API 可以被微服務調用。

然而,這種策略只是部分的解決方案。很可能應用的兩部分之一或者全部都是不可管理的,因此需要使用第三種策略來消除剩余的單體架構。

策略 3——抽出服務

第三種遷移策略就是從單體應用中抽取出某些模塊成為獨立微服務。每當抽取一個模塊變成微服務,單體應用就變簡單一些;一旦轉換足夠多的模塊,單體應用本身已經不成為問題了,要么消失了,要么簡單到成為一個服務。

排序那個模塊應該被轉成微服務

一個巨大的復雜單體應用由成十上百個模塊構成,每個都是被抽取對象。決定第一個被抽取模塊一般都是挑戰,一般最好是從最容易抽取的模塊開始,這會讓開發者積累足夠經驗,這些經驗可以為后續模塊化工作帶來巨大好處。

轉換模塊成為微服務一般很耗費時間,一般可以根據獲益程度來排序,一般從經常變化模塊開始會獲益最大。一旦轉換一個模塊為微服務,就可以將其開發部署成獨立模塊,從而加速開發進程。

將資源消耗大戶先抽取出來也是排序標準之一。例如,將內存數據庫抽取出來成為一個微服務會非常有用,可以將其部署在大內存主機上。同樣的,將對計算資源很敏感的算法應用抽取出來也是非常有益的,這種服務可以被部署在有很多 CPU 的主機上。通過將資源消耗模塊轉換成微服務,可以使得應用易于擴展。

查找現有粗粒度邊界來決定哪個模塊應該被抽取,也是很有益的,這使得移植工作更容易和簡單。例如,只與其他應用異步同步消息的模塊就是一個明顯邊界,可以很簡單容易地將其轉換為微服務。

如何抽取模塊

抽取模塊第一步就是定義好模塊和單體應用之間粗粒度接口,由于單體應用需要微服務的數據,反之亦然,因此更像是一個雙向 API。因為必須在負責依賴關系和細粒度接口模式之間做好平衡,因此開發這種 API 很有挑戰性,尤其對使用域模型模式的業務邏輯層來說更具有挑戰,因此經常需要改變代碼來解決依賴性問題,如圖所示:

​一旦完成粗粒度接口,也就將此模塊轉換成獨立微服務。為了實現,必須寫代碼使得單體應用和微服務之間通過使用進程間通信(IPC)機制的 API 來交換信息。如圖所示遷移前后對比:

 

從單體式架構遷移到微服務架構:三個策略<span><span><span><i style=完美敘述" src="http://p3.pstatp.com/large/pgc-image/154c174a35e0472a86e558deee9d9eee" _fcksavedurl="http://p3.pstatp.com/large/pgc-image/154c174a35e0472a86e558deee9d9eee" _fcksavedurl="http://p3.pstatp.com/large/pgc-image/154c174a35e0472a86e558deee9d9eee" width="640" height="859">

 

此例中,正在使用 Y 模塊的 Z 模塊是備選抽取模塊,其元素正在被 X 模塊使用,遷移第一步就是定義一套粗粒度 APIs,第一個接口應該是被 X 模塊使用的內部接口,用于激活 Z 模塊;第二個接口是被 Z 模塊使用的外部接口,用于激活 Y 模塊。

遷移第二步就是將模塊轉換成獨立服務。內部和外部接口都使用基于 IPC 機制的代碼,一般都會將 Z 模塊整合成一個微服務基礎框架,來出來割接過程中的問題,例如服務發現。

抽取完模塊,也就可以開發、部署和擴展另外一個服務,此服務獨立于單體應用和其它服務。可以從頭寫代碼實現服務;這種情況下,將服務和單體應用整合的 API 代碼成為容災層,在兩種域模型之間進行翻譯工作。每抽取一個服務,就朝著微服務方向前進一步。隨著時間推移,單體應用將會越來越簡單,用戶就可以增加更多獨立的微服務。 將現有應用遷移成微服務架構的現代化應用,不應該通過從頭重寫代碼方式實現,相反,應該通過逐步遷移的方式。有三種策略可以考慮:將新功能以微服務方式實現;將表現層與業務數據訪問層分離;將現存模塊抽取變成微服務。隨著時間推移,微服務數量會增加,開發團隊的彈性和效率將會大大增加。

 

責任編輯:武曉燕 來源: 今日頭條
相關推薦

2019-07-31 10:21:15

單體架構微服務

2023-08-31 17:13:01

架構軟件開發

2023-10-24 08:00:00

單體架構微服務

2022-08-05 07:37:39

單體架構遷移微服務

2019-01-07 08:10:54

微服務單體 Web

2022-12-22 09:00:00

微服務架構

2022-08-22 14:27:30

微服務遷移

2020-05-26 20:36:19

微服務架構轉型

2023-12-19 22:29:37

架構微服務系統

2018-07-04 14:17:10

微服務代碼開發

2022-12-21 16:13:31

微服務架構

2024-01-19 11:57:42

2022-04-08 09:00:00

微服務架構安全防火墻

2022-05-13 14:01:46

微服務架構安全微服務

2024-01-26 06:06:26

單體微服務容器化

2024-11-19 08:10:00

2023-11-01 11:17:26

單體架構微服務架構

2020-10-11 16:56:10

分解單體式數據庫數據庫微服務

2021-06-29 06:42:54

單體架構微服務

2018-04-26 10:13:32

云計算遷移云端
點贊
收藏

51CTO技術棧公眾號

成人一区二区在线| 美乳少妇欧美精品| 国产精品视频中文字幕| а√中文在线8| 成人综合婷婷国产精品久久免费| 欧美一区二区影院| 男人av资源站| 亚洲人成网亚洲欧洲无码| 欧美亚洲禁片免费| 国产一线二线三线女| 东热在线免费视频| 成熟亚洲日本毛茸茸凸凹| 国产精品久久久久久中文字| 国产av 一区二区三区| 少妇精品久久久一区二区三区 | 国产色综合视频| 国产精品日韩| 欧美激情亚洲国产| 纪美影视在线观看电视版使用方法| 日本久久伊人| 欧美三级日本三级少妇99| 国产真人做爰毛片视频直播| 巨大荫蒂视频欧美另类大| www国产精品av| 91沈先生播放一区二区| 中文字幕1区2区3区| 免费中文字幕日韩欧美| 欧美国产日韩一区二区三区| 韩国一级黄色录像| 精品国产乱码久久久久久1区2匹| 亚洲国产精品热久久| 亚洲国产午夜精品| 亚洲伦理网站| 欧美三级欧美一级| 天天碰免费视频| 久热在线观看视频| 亚洲成a天堂v人片| 8x8ⅹ国产精品一区二区二区| 日本美女高清在线观看免费| 国产欧美日韩在线视频| 久久亚洲免费| 婷婷国产在线| 99精品视频在线观看| 丁香婷婷久久久综合精品国产| ,一级淫片a看免费| 老司机免费视频一区二区| 国产精品扒开腿爽爽爽视频| 综合激情网五月| 在线不卡亚洲| 97视频在线观看视频免费视频| 18精品爽视频在线观看| 国内精品久久久久久久97牛牛 | 欧美大胆人体bbbb| 免费欧美一级片| 亚洲国产aⅴ精品一区二区三区| 欧美色视频在线观看| www.这里只有精品| 精品176极品一区| 欧美麻豆精品久久久久久| 色噜噜狠狠永久免费| 国产精品天堂蜜av在线播放| 欧美日韩国产影片| 天堂av.com| 99久久人爽人人添人人澡| 亚洲精品一区在线观看| 艳妇乳肉亭妇荡乳av| 亲子伦视频一区二区三区| 精品视频在线播放| 国产jk精品白丝av在线观看 | 中国一级黄色录像| 最新黄网在线观看| 亚洲va中文字幕| 91免费视频网站在线观看| 国产精品极品美女在线观看| 欧美探花视频资源| 亚洲精品一二三四| 欧美交a欧美精品喷水| 亚洲视频在线视频| 丰满少妇被猛烈进入一区二区| 欧美啪啪一区| 日本电影亚洲天堂| 亚洲图片小说视频| 国产99一区视频免费| 久久66热这里只有精品| aiai在线| 亚洲午夜在线电影| 91av俱乐部| 国产欧美88| 日韩黄色av网站| 亚洲 欧美 变态 另类 综合| 影音先锋日韩资源| 国产精品久久久久久中文字| www.色呦呦| 久久久亚洲欧洲日产国码αv| 一区二区三区四区五区视频| caoprom在线| 精品视频一区 二区 三区| wwwww在线观看| 国产成人高清| 久久久久国产视频| 中文字幕乱码人妻二区三区| 粉嫩高潮美女一区二区三区 | 91影院未满十八岁禁止入内| 你懂的在线看| 亚洲一区中文日韩| 欧美伦理片在线观看| 国产精品自在| www.亚洲男人天堂| 中文字幕视频网站| 国产·精品毛片| 宅男av一区二区三区| 日韩精品极品| 日韩一区二区视频| 秋霞网一区二区三区| 9国产精品视频| 91日韩久久| 麻豆视频在线| 欧洲视频一区二区| 性久久久久久久久久| 国产精品vip| 91香蕉电影院| 91在线播放网站| 欧美午夜片欧美片在线观看| 亚洲911精品成人18网站| 97在线精品| 国产精品久久久久不卡| 性xxxx视频播放免费| 亚洲你懂的在线视频| 亚洲小视频网站| av中文字幕一区二区| 欧美一级高清免费播放| 欧美自拍偷拍一区二区| 夜夜亚洲天天久久| 污污视频在线免费| 亚洲91精品| 成人免费在线视频网址| av大全在线免费看| 欧美日本精品一区二区三区| 性猛交娇小69hd| 久久永久免费| 日韩av免费电影| 国产精品极品美女在线观看| 亚洲一级片在线看| 进去里视频在线观看| 国产午夜精品久久| 丝袜制服一区二区三区| 欧美日韩伦理| 国产精品欧美日韩久久| 成a人v在线播放| 欧美午夜精品一区| 欧美成人久久久免费播放| 免费在线观看不卡| 香蕉精品视频在线| 精品视频成人| 欧美精品18videos性欧| 狠狠综合久久av一区二区| 亚洲成人一区二区| 538国产视频| 丝袜美腿亚洲一区| 亚洲高清精品中出| www久久久| 欧美大片免费观看| 天天综合网在线观看| 日韩欧美国产免费播放| 色婷婷国产精品免| 国产精品一区二区三区网站| 亚洲国产精品无码av| 日本午夜精品久久久| 国产精品精品视频一区二区三区| 日韩在线资源| 精品99久久久久久| youjizz在线视频| 国产精品久久久久久久久果冻传媒 | 一根才成人网| 中文字幕国产亚洲2019| av观看在线免费| 午夜精品久久久久| 亚洲第一综合网| 国产精品一二三四五| 国产妇女馒头高清泬20p多| 国产不卡一二三区| 亚洲伊人久久综合| 欧亚在线中文字幕免费| 最近2019年手机中文字幕| 亚洲爱爱综合网| 色妹子一区二区| 老湿机69福利| 久久久综合网站| www.51色.com| 亚洲制服av| 少妇高潮流白浆| 欧美日日夜夜| 成人天堂噜噜噜| 这里有精品可以观看| 久久久精品久久| 免费国产在线观看| 日韩一区二区免费在线观看| 黄色在线视频网址| 一区二区三区鲁丝不卡| 欧美黄色激情视频| 成人网在线播放| 97超碰成人在线| 性欧美videos另类喷潮| 91嫩草国产丨精品入口麻豆| 国产区精品区| 精品无码久久久久国产| 高清一区二区三区av| 日本午夜在线亚洲.国产| 青草视频在线免费直播| 中文字幕综合在线| 嫩草研究院在线观看| 精品国产凹凸成av人导航| 亚洲欧美日韩一区二区三区四区| 亚洲国产成人av网| 成人自拍小视频| 日本一区二区不卡视频| 日本少妇xxxx| 国产高清不卡一区| 亚洲一区精品视频在线观看| 日韩精品亚洲一区二区三区免费| 奇米影视亚洲色图| 欧美成人亚洲| 欧美 国产 精品| 欧美大片aaaa| 日本日本精品二区免费| 日韩成人午夜| 精品久久久久久亚洲| 一区二区三区在线资源| 91免费精品国偷自产在线| 电影亚洲一区| 国产精品久久久久77777| 小黄鸭精品aⅴ导航网站入口| 91精品国产沙发| 久久亚洲资源| 欧美黑人巨大精品一区二区| 超碰个人在线| 欧美巨乳在线观看| 制服丝袜在线播放| 欧美丰满老妇厨房牲生活| 超碰免费公开在线| 欧美日韩国产va另类| 在线观看小视频| 欧美大片免费看| 久久五月精品中文字幕| 欧美激情手机在线视频| 黄色在线观看视频网站| 欧美第一淫aaasss性| 欧美韩日亚洲| 久久久久一本一区二区青青蜜月| 欧美xxx黑人xxx水蜜桃| 国模精品系列视频| 三级在线看中文字幕完整版| 琪琪第一精品导航| 欧美日韩尤物久久| 国产精品热视频| 91麻豆精品国产91久久久更新资源速度超快| 国产一区二中文字幕在线看| 成年永久一区二区三区免费视频| 91最新在线免费观看| 亚洲福利合集| 九九热久久66| 成人精品中文字幕| 国产91av视频在线观看| 欧美成人一品| 69堂免费视频| 日韩福利电影在线| 亚洲女人在线观看| 成人aaaa免费全部观看| www.av欧美| 成人欧美一区二区三区小说| 久久久久久av无码免费网站| 欧美日韩久久久久| 岳乳丰满一区二区三区| 日韩你懂的在线观看| 三级毛片在线免费看| 影音先锋日韩有码| 手机在线免费看av| 日韩免费精品视频| 91精品一久久香蕉国产线看观看| 国产一区精品视频| 色婷婷亚洲mv天堂mv在影片| 丁香婷婷综合激情| 日韩国产欧美在线播放| 天天干天天曰天天操| 91女人视频在线观看| 九九精品视频免费| 日韩欧美成人免费视频| 99国产精品99| 亚洲欧洲日本专区| 污网站在线免费看| 日韩免费av一区二区| 亚洲国产精品免费视频| 日本在线观看不卡| 亚洲高清久久| 999这里有精品| 久久综合久色欧美综合狠狠| 国语对白在线播放| 色婷婷久久久久swag精品| 精品国自产在线观看| 国产亚洲a∨片在线观看| 欧美xxxxhdvideosex| 国产精品中文字幕在线观看| 精品人人人人| 9色视频在线观看| 蜜桃久久久久久久| 亚洲 欧美 日韩在线| 亚洲精品老司机| 最近中文字幕在线视频| 日韩av中文字幕在线| av免费网站在线| 国产精品欧美久久久| 九九综合久久| 日本在线xxx| 国产福利91精品| 91制片厂在线| 欧洲av一区二区嗯嗯嗯啊| 天堂√在线中文官网在线| 欧美大片va欧美在线播放| 国产第一亚洲| 日产中文字幕在线精品一区| 国产欧美一区二区色老头| zjzjzjzjzj亚洲女人| 亚洲欧美日韩人成在线播放| 亚洲天堂avav| 中文国产成人精品| 日韩精品麻豆| 欧洲av一区| 男人的天堂亚洲| 色无极影院亚洲| 欧美日韩在线影院| 亚洲av成人精品日韩在线播放| 欧美放荡办公室videos4k| 免费欧美网站| 男人日女人的bb| 国产一区二区三区黄视频| 人人澡人人澡人人看| 欧美另类高清zo欧美| 青青青青在线| 成人国产精品一区二区| 亚洲国产一成人久久精品| 99re6在线观看| 亚洲品质自拍视频网站| 97超碰国产在线| 久久视频精品在线| 亚洲高清国产拍精品26u| 激情五月五月婷婷| 国产高清精品在线| 久久久久久久99| 亚洲精品电影在线| 成人直播视频| 视频一区视频二区视频| 老司机精品视频导航| 久久国产精品国语对白| 欧美一级国产精品| av午夜在线观看| 看高清中日韩色视频| 日日夜夜一区二区| 国产喷水在线观看| 欧美一二三四在线| 182在线播放| 欧日韩一区二区三区| 毛片av中文字幕一区二区| 日韩精品一区二区三区在线视频| 日韩亚洲欧美一区| 黄色在线免费观看网站| 欧美一区二区三区成人久久片| 蜜臂av日日欢夜夜爽一区| 黄色a级片在线观看| 欧美r级电影在线观看| 三级在线看中文字幕完整版| 亚洲午夜精品久久| 国产风韵犹存在线视精品| 亚洲午夜18毛片在线看| 中文字幕日韩av| 97一区二区国产好的精华液| 妺妺窝人体色www在线小说| 国产欧美一区视频| www日本在线| 国产精品91久久久久久| 国产精品久久久久久久久久10秀 | 中文字幕免费播放| 久久91亚洲精品中文字幕| 神马久久av| 一区二区久久精品| 黄网动漫久久久| 免费在线看黄网站| 国内精品**久久毛片app| 免费精品视频最新在线| 国产一级大片在线观看| 一区二区三区久久精品| 亚洲电影一区| 色婷婷成人在线| 午夜精品久久久| 国产精品va在线观看视色| 久精品国产欧美| 国产乱码精品一品二品| 日本免费在线观看视频| 欧美巨乳美女视频| 欧美国产美女| 亚洲激情视频小说|