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

微服務(wù)架構(gòu)是如何演進的?

開發(fā)
今天跟大家分享一下微服務(wù)架構(gòu)和相關(guān)的組件,介紹一下他們是什么,以及為什么要使用微服務(wù)架構(gòu)和這些組件。

大家好,我是三友~~

今天跟大家分享一下微服務(wù)架構(gòu)和相關(guān)的組件,介紹一下他們是什么,以及為什么要使用微服務(wù)架構(gòu)和這些組件。

本文側(cè)重于簡明地表達微服務(wù)架構(gòu)的全局圖景,因此不會涉及具體如何使用組件等細節(jié)。

要理解微服務(wù),首先要先理解不是微服務(wù)的那些。通常跟微服務(wù)相對的是單體應(yīng)用,即將所有功能都打包成在一個獨立單元的應(yīng)用程序。從單體應(yīng)用到微服務(wù)并不是一蹴而就的,這是一個逐漸演變的過程。本文將以一個網(wǎng)上超市應(yīng)用為例來說明這一過程。

一、最初的需求

幾年前,小明和小皮一起創(chuàng)業(yè)做網(wǎng)上超市。小明負責(zé)程序開發(fā),小皮負責(zé)其他事宜。當(dāng)時互聯(lián)網(wǎng)還不發(fā)達,網(wǎng)上超市還是藍海。只要功能實現(xiàn)了就能隨便賺錢。所以他們的需求很簡單,只需要一個網(wǎng)站掛在公網(wǎng),用戶能夠在這個網(wǎng)站上瀏覽商品、購買商品;另外還需一個管理后臺,可以管理商品、用戶、以及訂單數(shù)據(jù)。

我們整理一下功能清單:

(1) 網(wǎng)站

  • 用戶注冊、登錄功能
  • 商品展示
  • 下單

(2) 管理后臺

  • 用戶管理
  • 商品管理
  • 訂單管理

由于需求簡單,小明左手右手一個慢動作,網(wǎng)站就做好了。管理后臺出于安全考慮,不和網(wǎng)站做在一起,小明右手左手慢動作重播,管理網(wǎng)站也做好了。總體架構(gòu)圖如下:

小明揮一揮手,找了家云服務(wù)部署上去,網(wǎng)站就上線了。上線后好評如潮,深受各類肥宅喜愛。小明小皮美滋滋地開始躺著收錢。

二、隨著業(yè)務(wù)發(fā)展……

好景不長,沒過幾天,各類網(wǎng)上超市緊跟著拔地而起,對小明小皮造成了強烈的沖擊。

在競爭的壓力下,小明小皮決定開展一些營銷手段:

  • 開展促銷活動。比如元旦全場打折,春節(jié)買二送一,情人節(jié)狗糧優(yōu)惠券等等。
  • 拓展渠道,新增移動端營銷。除了網(wǎng)站外,還需要開發(fā)移動端APP,微信小程序等。
  • 精準(zhǔn)營銷。利用歷史數(shù)據(jù)對用戶進行分析,提供個性化服務(wù)。
  • ……

這些活動都需要程序開發(fā)的支持。小明拉了同學(xué)小紅加入團隊。小紅負責(zé)數(shù)據(jù)分析以及移動端相關(guān)開發(fā)。小明負責(zé)促銷活動相關(guān)功能的開發(fā)。

因為開發(fā)任務(wù)比較緊迫,小明小紅沒有好好規(guī)劃整個系統(tǒng)的架構(gòu),隨便拍了拍腦袋,決定把促銷管理和數(shù)據(jù)分析放在管理后臺里,微信和移動端APP另外搭建。通宵了幾天后,新功能和新應(yīng)用基本完工。這時的架構(gòu)圖如下:

這一階段存在很多不合理的地方:

  • 網(wǎng)站和移動端應(yīng)用有很多相同業(yè)務(wù)邏輯的重復(fù)代碼。
  • 數(shù)據(jù)有時候通過數(shù)據(jù)庫共享,有時候通過接口調(diào)用傳輸。接口調(diào)用關(guān)系雜亂。
  • 單個應(yīng)用為了給其他應(yīng)用提供接口,漸漸地越改越大,包含了很多本來就不屬于它的邏輯。應(yīng)用邊界模糊,功能歸屬混亂。
  • 管理后臺在一開始的設(shè)計中保障級別較低。加入數(shù)據(jù)分析和促銷管理相關(guān)功能后出現(xiàn)性能瓶頸,影響了其他應(yīng)用。
  • 數(shù)據(jù)庫表結(jié)構(gòu)被多個應(yīng)用依賴,無法重構(gòu)和優(yōu)化。
  • 所有應(yīng)用都在一個數(shù)據(jù)庫上操作,數(shù)據(jù)庫出現(xiàn)性能瓶頸。特別是數(shù)據(jù)分析跑起來的時候,數(shù)據(jù)庫性能急劇下降。
  • 開發(fā)、測試、部署、維護愈發(fā)困難。即使只改動一個小功能,也需要整個應(yīng)用一起發(fā)布。有時候發(fā)布會不小心帶上了一些未經(jīng)測試的代碼,或者修改了一個功能后,另一個意想不到的地方出錯了。為了減輕發(fā)布可能產(chǎn)生的問題的影響和線上業(yè)務(wù)停頓的影響,所有應(yīng)用都要在凌晨三四點執(zhí)行發(fā)布。發(fā)布后為了驗證應(yīng)用正常運行,還得盯到第二天白天的用戶高峰期……
  • 團隊出現(xiàn)推諉扯皮現(xiàn)象。關(guān)于一些公用的功能應(yīng)該建設(shè)在哪個應(yīng)用上的問題常常要爭論很久,最后要么干脆各做各的,或者隨便放個地方但是都不維護。

盡管有著諸多問題,但也不能否認這一階段的成果:快速地根據(jù)業(yè)務(wù)變化建設(shè)了系統(tǒng)。不過緊迫且繁重的任務(wù)容易使人陷入局部、短淺的思維方式,從而做出妥協(xié)式的決策。在這種架構(gòu)中,每個人都只關(guān)注在自己的一畝三分地,缺乏全局的、長遠的設(shè)計。長此以往,系統(tǒng)建設(shè)將會越來越困難,甚至陷入不斷推翻、重建的循環(huán)。

三、是時候做出改變了

幸好小明和小紅是有追求有理想的好青年。意識到問題后,小明和小紅從瑣碎的業(yè)務(wù)需求中騰出了一部分精力,開始梳理整體架構(gòu),針對問題準(zhǔn)備著手改造。

要做改造,首先你需要有足夠的精力和資源。如果你的需求方(業(yè)務(wù)人員、項目經(jīng)理、上司等)很強勢地一心追求需求進度,以至于你無法挪出額外的精力和資源的話,那么你可能無法做任何事……

在編程的世界中,最重要的便是抽象能力。微服務(wù)改造的過程實際上也是個抽象的過程。小明和小紅整理了網(wǎng)上超市的業(yè)務(wù)邏輯,抽象出公用的業(yè)務(wù)能力,做成幾個公共服務(wù):

  • 用戶服務(wù)
  • 商品服務(wù)
  • 促銷服務(wù)
  • 訂單服務(wù)
  • 數(shù)據(jù)分析服務(wù)

各個應(yīng)用后臺只需從這些服務(wù)獲取所需的數(shù)據(jù),從而刪去了大量冗余的代碼,就剩個輕薄的控制層和前端。這一階段的架構(gòu)如下:

這個階段只是將服務(wù)分開了,數(shù)據(jù)庫依然是共用的,所以一些煙囪式系統(tǒng)的缺點仍然存在:

  • 數(shù)據(jù)庫成為性能瓶頸,并且有單點故障的風(fēng)險。
  • 數(shù)據(jù)管理趨向混亂。即使一開始有良好的模塊化設(shè)計,隨著時間推移,總會有一個服務(wù)直接從數(shù)據(jù)庫取另一個服務(wù)的數(shù)據(jù)的現(xiàn)象。
  • 數(shù)據(jù)庫表結(jié)構(gòu)可能被多個服務(wù)依賴,牽一發(fā)而動全身,很難調(diào)整。

如果一直保持共用數(shù)據(jù)庫的模式,則整個架構(gòu)會越來越僵化,失去了微服務(wù)架構(gòu)的意義。因此小明和小紅一鼓作氣,把數(shù)據(jù)庫也拆分了。所有持久化層相互隔離,由各個服務(wù)自己負責(zé)。另外,為了提高系統(tǒng)的實時性,加入了消息隊列機制。架構(gòu)如下:

完全拆分后各個服務(wù)可以采用異構(gòu)的技術(shù)。比如數(shù)據(jù)分析服務(wù)可以使用數(shù)據(jù)倉庫作為持久化層,以便于高效地做一些統(tǒng)計計算;商品服務(wù)和促銷服務(wù)訪問頻率比較大,因此加入了緩存機制等。

還有一種抽象出公共邏輯的方法是把這些公共邏輯做成公共的框架庫。這種方法可以減少服務(wù)調(diào)用的性能損耗。但是這種方法的管理成本非常高昂,很難保證所有應(yīng)用版本的一致性。

數(shù)據(jù)庫拆分也有一些問題和挑戰(zhàn):比如說跨庫級聯(lián)的需求,通過服務(wù)查詢數(shù)據(jù)顆粒度的粗細問題等。但是這些問題可以通過合理的設(shè)計來解決。總體來說,數(shù)據(jù)庫拆分是一個利大于弊的。

微服務(wù)架構(gòu)還有一個技術(shù)外的好處,它使整個系統(tǒng)的分工更加明確,責(zé)任更加清晰,每個人專心負責(zé)為其他人提供更好的服務(wù)。在單體應(yīng)用的時代,公共的業(yè)務(wù)功能經(jīng)常沒有明確的歸屬。最后要么各做各的,每個人都重新實現(xiàn)了一遍;要么是隨機一個人(一般是能力比較強或者比較熱心的人)做到他負責(zé)的應(yīng)用里面。

在后者的情況下,這個人在負責(zé)自己應(yīng)用之外,還要額外負責(zé)給別人提供這些公共的功能——而這個功能本來是無人負責(zé)的,僅僅因為他能力較強/比較熱心,就莫名地背鍋(這種情況還被美其名曰能者多勞)。結(jié)果最后大家都不愿意提供公共的功能。長此以往,團隊里的人漸漸變得各自為政,不再關(guān)心全局的架構(gòu)設(shè)計。

從這個角度上看,使用微服務(wù)架構(gòu)同時也需要組織結(jié)構(gòu)做相應(yīng)的調(diào)整。所以說做微服務(wù)改造需要管理者的支持。

改造完成后,小明和小紅分清楚各自的鍋。兩人十分滿意,一切就像是麥克斯韋方程組一樣漂亮完美。

然而……

四、沒有銀彈

春天來了,萬物復(fù)蘇,又到了一年一度的購物狂歡節(jié)。眼看著日訂單數(shù)量蹭蹭地上漲,小皮小明小紅喜笑顏開。可惜好景不長,樂極生悲,突然嘣的一下,系統(tǒng)掛了。

以往單體應(yīng)用,排查問題通常是看一下日志,研究錯誤信息和調(diào)用堆棧。而微服務(wù)架構(gòu)整個應(yīng)用分散成多個服務(wù),定位故障點非常困難。小明一臺機器一臺機器地查看日志,一個服務(wù)一個服務(wù)的手工調(diào)用。經(jīng)過十幾分鐘的查找,小明終于定位到故障點:促銷服務(wù)由于接收的請求量太大而停止響應(yīng)了。其他服務(wù)都直接或間接地會調(diào)用促銷服務(wù),于是也跟著宕機了。

在微服務(wù)架構(gòu)中,一個服務(wù)故障可能會產(chǎn)生雪崩效用,導(dǎo)致整個系統(tǒng)故障。其實在節(jié)前,小明和小紅是有做過請求量評估的。按照預(yù)計,服務(wù)器資源是足以支持節(jié)日的請求量的,所以肯定是哪里出了問題。不過形勢緊急,隨著每一分每一秒流逝的都是白花花的銀子,因此小明也沒時間排查問題,當(dāng)機立斷在云上新建了幾臺虛擬機,然后一臺一臺地部署新的促銷服務(wù)節(jié)點。幾分鐘的操作后,系統(tǒng)總算是勉強恢復(fù)正常了。整個故障時間內(nèi)估計損失了幾十萬的銷售額,三人的心在滴血……

事后,小明簡單寫了個日志分析工具(量太大了,文本編輯器幾乎打不開,打開了肉眼也看不過來),統(tǒng)計了促銷服務(wù)的訪問日志,發(fā)現(xiàn)在故障期間,商品服務(wù)由于代碼問題,在某些場景下會對促銷服務(wù)發(fā)起大量請求。這個問題并不復(fù)雜,小明手指抖一抖,修復(fù)了這個價值幾十萬的Bug。

問題是解決了,但誰也無法保證不會再發(fā)生類似的其他問題。微服務(wù)架構(gòu)雖然邏輯設(shè)計上看是完美的,但就像積木搭建的華麗宮殿一樣,經(jīng)不起風(fēng)吹草動。微服務(wù)架構(gòu)雖然解決了舊問題,也引入了新的問題:

  • 微服務(wù)架構(gòu)整個應(yīng)用分散成多個服務(wù),定位故障點非常困難。
  • 穩(wěn)定性下降。服務(wù)數(shù)量變多導(dǎo)致其中一個服務(wù)出現(xiàn)故障的概率增大,并且一個服務(wù)故障可能導(dǎo)致整個系統(tǒng)掛掉。事實上,在大訪問量的生產(chǎn)場景下,故障總是會出現(xiàn)的。
  • 服務(wù)數(shù)量非常多,部署、管理的工作量很大。
  • 開發(fā)方面:如何保證各個服務(wù)在持續(xù)開發(fā)的情況下仍然保持協(xié)同合作。
  • 測試方面:服務(wù)拆分后,幾乎所有功能都會涉及多個服務(wù)。原本單個程序的測試變?yōu)榉?wù)間調(diào)用的測試。測試變得更加復(fù)雜。

小明小紅痛定思痛,決心好好解決這些問題。對故障的處理一般從兩方面入手,一方面盡量減少故障發(fā)生的概率,另一方面降低故障造成的影響。

五、監(jiān)控 - 發(fā)現(xiàn)故障的征兆

在高并發(fā)分布式的場景下,故障經(jīng)常是突然間就雪崩式爆發(fā)。所以必須建立完善的監(jiān)控體系,盡可能發(fā)現(xiàn)故障的征兆。

微服務(wù)架構(gòu)中組件繁多,各個組件所需要監(jiān)控的指標(biāo)不同。比如Redis緩存一般監(jiān)控占用內(nèi)存值、網(wǎng)絡(luò)流量,數(shù)據(jù)庫監(jiān)控連接數(shù)、磁盤空間,業(yè)務(wù)服務(wù)監(jiān)控并發(fā)數(shù)、響應(yīng)延遲、錯誤率等。因此如果做一個大而全的監(jiān)控系統(tǒng)來監(jiān)控各個組件是不大現(xiàn)實的,而且擴展性會很差。一般的做法是讓各個組件提供報告自己當(dāng)前狀態(tài)的接口(metrics接口),這個接口輸出的數(shù)據(jù)格式應(yīng)該是一致的。然后部署一個指標(biāo)采集器組件,定時從這些接口獲取并保持組件狀態(tài),同時提供查詢服務(wù)。最后還需要一個UI,從指標(biāo)采集器查詢各項指標(biāo),繪制監(jiān)控界面或者根據(jù)閾值發(fā)出告警。

大部分組件都不需要自己動手開發(fā),網(wǎng)絡(luò)上有開源組件。小明下載了RedisExporter和MySQLExporter,這兩個組件分別提供了Redis緩存和MySQL數(shù)據(jù)庫的指標(biāo)接口。微服務(wù)則根據(jù)各個服務(wù)的業(yè)務(wù)邏輯實現(xiàn)自定義的指標(biāo)接口。然后小明采用Prometheus作為指標(biāo)采集器,Grafana配置監(jiān)控界面和郵件告警。這樣一套微服務(wù)監(jiān)控系統(tǒng)就搭建起來了:

六、定位問題 - 鏈路跟蹤

在微服務(wù)架構(gòu)下,一個用戶的請求往往涉及多個內(nèi)部服務(wù)調(diào)用。為了方便定位問題,需要能夠記錄每個用戶請求時,微服務(wù)內(nèi)部產(chǎn)生了多少服務(wù)調(diào)用,及其調(diào)用關(guān)系。這個叫做鏈路跟蹤。

我們用一個Istio文檔里的鏈路跟蹤例子來看看效果:

圖片來自Istio文檔

從圖中可以看到,這是一個用戶訪問productpage頁面的請求。在請求過程中,productpage服務(wù)順序調(diào)用了details和reviews服務(wù)的接口。而reviews服務(wù)在響應(yīng)過程中又調(diào)用了ratings的接口。整個鏈路跟蹤的記錄是一棵樹:

要實現(xiàn)鏈路跟蹤,每次服務(wù)調(diào)用會在HTTP的HEADERS中記錄至少記錄四項數(shù)據(jù):

  • traceId:traceId標(biāo)識一個用戶請求的調(diào)用鏈路。具有相同traceId的調(diào)用屬于同一條鏈路。
  • spanId:標(biāo)識一次服務(wù)調(diào)用的ID,即鏈路跟蹤的節(jié)點ID。
  • parentId:父節(jié)點的spanId。
  • requestTime & responseTime:請求時間和響應(yīng)時間。

另外,還需要調(diào)用日志收集與存儲的組件,以及展示鏈路調(diào)用的UI組件。

以上只是一個極簡的說明,關(guān)于鏈路跟蹤的理論依據(jù)可詳見Google的Dapper。

了解了理論基礎(chǔ)后,小明選用了Dapper的一個開源實現(xiàn)Zipkin。然后手指一抖,寫了個HTTP請求的攔截器,在每次HTTP請求時生成這些數(shù)據(jù)注入到HEADERS,同時異步發(fā)送調(diào)用日志到Zipkin的日志收集器中。這里額外提一下,HTTP請求的攔截器,可以在微服務(wù)的代碼中實現(xiàn),也可以使用一個網(wǎng)絡(luò)代理組件來實現(xiàn)(不過這樣子每個微服務(wù)都需要加一層代理)。

鏈路跟蹤只能定位到哪個服務(wù)出現(xiàn)問題,不能提供具體的錯誤信息。查找具體的錯誤信息的能力則需要由日志分析組件來提供。

七、分析問題 - 日志分析

日志分析組件應(yīng)該在微服務(wù)興起之前就被廣泛使用了。即使單體應(yīng)用架構(gòu),當(dāng)訪問數(shù)變大、或服務(wù)器規(guī)模增多時,日志文件的大小會膨脹到難以用文本編輯器進行訪問,更糟的是它們分散在多臺服務(wù)器上面。排查一個問題,需要登錄到各臺服務(wù)器去獲取日志文件,一個一個地查找(而且打開、查找都很慢)想要的日志信息。

因此,在應(yīng)用規(guī)模變大時,我們需要一個日志的“搜索引擎”。以便于能準(zhǔn)確地找到想要的日志。另外,數(shù)據(jù)源一側(cè)還需要收集日志的組件和展示結(jié)果的UI組件:

小明調(diào)查了一下,使用了大名鼎鼎的ELK日志分析組件。ELK是Elasticsearch、Logstash和Kibana三個組件的縮寫。

  • Elasticsearch:搜索引擎,同時也是日志的存儲。
  • Logstash:日志采集器,它接收日志輸入,對日志進行一些預(yù)處理,然后輸出到Elasticsearch。
  • Kibana:UI組件,通過Elasticsearch的API查找數(shù)據(jù)并展示給用戶。

最后還有一個小問題是如何將日志發(fā)送到Logstash。一種方案是在日志輸出的時候直接調(diào)用Logstash接口將日志發(fā)送過去。這樣一來又(咦,為啥要用“又”)要修改代碼……于是小明選用了另一種方案:日志仍然輸出到文件,每個服務(wù)里再部署個Agent掃描日志文件然后輸出給Logstash。

八、網(wǎng)關(guān) - 權(quán)限控制,服務(wù)治理

拆分成微服務(wù)后,出現(xiàn)大量的服務(wù),大量的接口,使得整個調(diào)用關(guān)系亂糟糟的。經(jīng)常在開發(fā)過程中,寫著寫著,忽然想不起某個數(shù)據(jù)應(yīng)該調(diào)用哪個服務(wù)。或者寫歪了,調(diào)用了不該調(diào)用的服務(wù),本來一個只讀的功能結(jié)果修改了數(shù)據(jù)……

為了應(yīng)對這些情況,微服務(wù)的調(diào)用需要一個把關(guān)的東西,也就是網(wǎng)關(guān)。在調(diào)用者和被調(diào)用者中間加一層網(wǎng)關(guān),每次調(diào)用時進行權(quán)限校驗。另外,網(wǎng)關(guān)也可以作為一個提供服務(wù)接口文檔的平臺。

使用網(wǎng)關(guān)有一個問題就是要決定在多大粒度上使用:最粗粒度的方案是整個微服務(wù)一個網(wǎng)關(guān),微服務(wù)外部通過網(wǎng)關(guān)訪問微服務(wù),微服務(wù)內(nèi)部則直接調(diào)用;最細粒度則是所有調(diào)用,不管是微服務(wù)內(nèi)部調(diào)用或者來自外部的調(diào)用,都必須通過網(wǎng)關(guān)。折中的方案是按照業(yè)務(wù)領(lǐng)域?qū)⑽⒎?wù)分成幾個區(qū),區(qū)內(nèi)直接調(diào)用,區(qū)間通過網(wǎng)關(guān)調(diào)用。

由于整個網(wǎng)上超市的服務(wù)數(shù)量還不算特別多,小明采用的最粗粒度的方案:

九、服務(wù)注冊與發(fā)現(xiàn) - 動態(tài)擴容

前面的組件,都是旨在降低故障發(fā)生的可能性。然而故障總是會發(fā)生的,所以另一個需要研究的是如何降低故障產(chǎn)生的影響。

最粗暴的(也是最常用的)故障處理策略就是冗余。一般來說,一個服務(wù)都會部署多個實例,這樣一來能夠分擔(dān)壓力提高性能,二來即使一個實例掛了其他實例還能響應(yīng)。

冗余的一個問題是使用幾個冗余?這個問題在時間軸上并沒有一個切確的答案。根據(jù)服務(wù)功能、時間段的不同,需要不同數(shù)量的實例。比如在平日里,可能4個實例已經(jīng)夠用;而在促銷活動時,流量大增,可能需要40個實例。因此冗余數(shù)量并不是一個固定的值,而是根據(jù)需要實時調(diào)整的。

一般來說新增實例的操作為:

  • 部署新實例
  • 將新實例注冊到負載均衡或DNS上

操作只有兩步,但如果注冊到負載均衡或DNS的操作為人工操作的話,那事情就不簡單了。想想新增40個實例后,要手工輸入40個IP的感覺……

解決這個問題的方案是服務(wù)自動注冊與發(fā)現(xiàn)。首先,需要部署一個服務(wù)發(fā)現(xiàn)服務(wù),它提供所有已注冊服務(wù)的地址信息的服務(wù)。DNS也算是一種服務(wù)發(fā)現(xiàn)服務(wù)。然后各個應(yīng)用服務(wù)在啟動時自動將自己注冊到服務(wù)發(fā)現(xiàn)服務(wù)上。并且應(yīng)用服務(wù)啟動后會實時(定期)從服務(wù)發(fā)現(xiàn)服務(wù)同步各個應(yīng)用服務(wù)的地址列表到本地。服務(wù)發(fā)現(xiàn)服務(wù)也會定期檢查應(yīng)用服務(wù)的健康狀態(tài),去掉不健康的實例地址。這樣新增實例時只需要部署新實例,實例下線時直接關(guān)停服務(wù)即可,服務(wù)發(fā)現(xiàn)會自動檢查服務(wù)實例的增減。

服務(wù)發(fā)現(xiàn)還會跟客戶端負載均衡配合使用。由于應(yīng)用服務(wù)已經(jīng)同步服務(wù)地址列表在本地了,所以訪問微服務(wù)時,可以自己決定負載策略。甚至可以在服務(wù)注冊時加入一些元數(shù)據(jù)(服務(wù)版本等信息),客戶端負載則根據(jù)這些元數(shù)據(jù)進行流量控制,實現(xiàn)A/B測試、藍綠發(fā)布等功能。

服務(wù)發(fā)現(xiàn)有很多組件可以選擇,比如說Zookeeper 、Eureka、Consul、Etcd等。不過小明覺得自己水平不錯,想炫技,于是基于Redis自己寫了一個……

十、熔斷、服務(wù)降級、限流

1.熔斷

當(dāng)一個服務(wù)因為各種原因停止響應(yīng)時,調(diào)用方通常會等待一段時間,然后超時或者收到錯誤返回。如果調(diào)用鏈路比較長,可能會導(dǎo)致請求堆積,整條鏈路占用大量資源一直在等待下游響應(yīng)。所以當(dāng)多次訪問一個服務(wù)失敗時,應(yīng)熔斷,標(biāo)記該服務(wù)已停止工作,直接返回錯誤。直至該服務(wù)恢復(fù)正常后再重新建立連接。

圖片來自《微服務(wù)設(shè)計》

2.服務(wù)降級

當(dāng)下游服務(wù)停止工作后,如果該服務(wù)并非核心業(yè)務(wù),則上游服務(wù)應(yīng)該降級,以保證核心業(yè)務(wù)不中斷。比如網(wǎng)上超市下單界面有一個推薦商品湊單的功能,當(dāng)推薦模塊掛了后,下單功能不能一起掛掉,只需要暫時關(guān)閉推薦功能即可。

3.限流

一個服務(wù)掛掉后,上游服務(wù)或者用戶一般會習(xí)慣性地重試訪問。這導(dǎo)致一旦服務(wù)恢復(fù)正常,很可能因為瞬間網(wǎng)絡(luò)流量過大又立刻掛掉,在棺材里重復(fù)著仰臥起坐。因此服務(wù)需要能夠自我保護——限流。限流策略有很多,最簡單的比如當(dāng)單位時間內(nèi)請求數(shù)過多時,丟棄多余的請求。另外,也可以考慮分區(qū)限流。僅拒絕來自產(chǎn)生大量請求的服務(wù)的請求。例如商品服務(wù)和訂單服務(wù)都需要訪問促銷服務(wù),商品服務(wù)由于代碼問題發(fā)起了大量請求,促銷服務(wù)則只限制來自商品服務(wù)的請求,來自訂單服務(wù)的請求則正常響應(yīng)。

十一、測試

微服務(wù)架構(gòu)下,測試分為三個層次:

  • 端到端測試:覆蓋整個系統(tǒng),一般在用戶界面機型測試。
  • 服務(wù)測試:針對服務(wù)接口進行測試。
  • 單元測試:針對代碼單元進行測試。

三種測試從上到下實施的容易程度遞增,但是測試效果遞減。端到端測試最費時費力,但是通過測試后我們對系統(tǒng)最有信心。單元測試最容易實施,效率也最高,但是測試后不能保證整個系統(tǒng)沒有問題。

由于端到端測試實施難度較大,一般只對核心功能做端到端測試。一旦端到端測試失敗,則需要將其分解到單元測試:則分析失敗原因,然后編寫單元測試來重現(xiàn)這個問題,這樣未來我們便可以更快地捕獲同樣的錯誤。

服務(wù)測試的難度在于服務(wù)會經(jīng)常依賴一些其他服務(wù)。這個問題可以通過Mock Server解決:

單元測試大家都很熟悉了。我們一般會編寫大量的單元測試(包括回歸測試)盡量覆蓋所有代碼。

十二、微服務(wù)框架

指標(biāo)接口、鏈路跟蹤注入、日志引流、服務(wù)注冊發(fā)現(xiàn)、路由規(guī)則等組件以及熔斷、限流等功能都需要在應(yīng)用服務(wù)上添加一些對接代碼。如果讓每個應(yīng)用服務(wù)自己實現(xiàn)是非常耗時耗力的。基于DRY的原則,小明開發(fā)了一套微服務(wù)框架,將與各個組件對接的代碼和另外一些公共代碼抽離到框架中,所有的應(yīng)用服務(wù)都統(tǒng)一使用這套框架進行開發(fā)。

使用微服務(wù)框架可以實現(xiàn)很多自定義的功能。甚至可以將程序調(diào)用堆棧信息注入到鏈路跟蹤,實現(xiàn)代碼級別的鏈路跟蹤。或者輸出線程池、連接池的狀態(tài)信息,實時監(jiān)控服務(wù)底層狀態(tài)。

使用統(tǒng)一的微服務(wù)框架有一個比較嚴重的問題:框架更新成本很高。每次框架升級,都需要所有應(yīng)用服務(wù)配合升級。當(dāng)然,一般會使用兼容方案,留出一段并行時間等待所有應(yīng)用服務(wù)升級。但是如果應(yīng)用服務(wù)非常多時,升級時間可能會非常漫長。并且有一些很穩(wěn)定幾乎不更新的應(yīng)用服務(wù),其負責(zé)人可能會拒絕升級……因此,使用統(tǒng)一微服務(wù)框架需要完善的版本管理方法和開發(fā)管理規(guī)范。

十三、另一條路 - Service Mesh

另一種抽象公共代碼的方法是直接將這些代碼抽象到一個反向代理組件。每個服務(wù)都額外部署這個代理組件,所有出站入站的流量都通過該組件進行處理和轉(zhuǎn)發(fā)。這個組件被稱為Sidecar。

Sidecar不會產(chǎn)生額外網(wǎng)絡(luò)成本。Sidecar會和微服務(wù)節(jié)點部署在同一臺主機上并且共用相同的虛擬網(wǎng)卡。所以sidecar和微服務(wù)節(jié)點的通信實際上都只是通過內(nèi)存拷貝實現(xiàn)的。

圖片來自:Pattern: Service Mesh

Sidecar只負責(zé)網(wǎng)絡(luò)通信。還需要有個組件來統(tǒng)一管理所有sidecar的配置。在Service Mesh中,負責(zé)網(wǎng)絡(luò)通信的部分叫數(shù)據(jù)平面(data plane),負責(zé)配置管理的部分叫控制平面(control plane)。數(shù)據(jù)平面和控制平面構(gòu)成了Service Mesh的基本架構(gòu)。

圖片來自:Pattern: Service Mesh

Sevice Mesh相比于微服務(wù)框架的優(yōu)點在于它不侵入代碼,升級和維護更方便。它經(jīng)常被詬病的則是性能問題。即使回環(huán)網(wǎng)絡(luò)不會產(chǎn)生實際的網(wǎng)絡(luò)請求,但仍然有內(nèi)存拷貝的額外成本。另外有一些集中式的流量處理也會影響性能。

十四、結(jié)束、也是開始

微服務(wù)不是架構(gòu)演變的終點。往細走還有Serverless、FaaS等方向。另一方面也有人在唱合久必分分久必合,重新發(fā)現(xiàn)單體架構(gòu)……

責(zé)任編輯:趙寧寧 來源: 三友的java日記
相關(guān)推薦

2021-06-07 10:13:01

單體架構(gòu)系統(tǒng)

2024-06-05 12:03:43

微服務(wù)架構(gòu)場景

2024-11-14 08:08:14

2020-08-28 08:29:40

云原生微服務(wù)編程

2024-06-03 10:19:05

2023-11-21 08:37:09

2023-10-11 07:29:21

2021-08-03 07:21:14

架構(gòu)微服務(wù)開發(fā)

2024-04-24 07:00:00

Redis架構(gòu)數(shù)據(jù)持久化

2024-11-06 16:27:12

2021-12-29 08:30:48

微服務(wù)架構(gòu)開發(fā)

2024-03-06 11:22:33

架構(gòu)演進技巧

2019-12-31 10:33:48

架構(gòu)運維技術(shù)

2017-08-31 09:39:56

微服務(wù)架構(gòu)演進

2021-06-30 10:16:54

微服務(wù)架構(gòu)測試

2023-07-28 09:23:24

微服務(wù)架構(gòu)

2018-11-15 07:56:26

2017-09-13 13:42:09

微服務(wù)緩存架構(gòu)

2019-03-26 09:37:11

ES系統(tǒng)架構(gòu)

2019-01-14 09:06:40

LBS定位系統(tǒng)架構(gòu)
點贊
收藏

51CTO技術(shù)棧公眾號

heyzo在线| www国产一区| 日韩精品中文字幕第1页| 欧美老女人第四色| 日韩人妻一区二区三区蜜桃视频| 国产av精国产传媒| 性欧美暴力猛交另类hd| 色哟哟入口国产精品| 日韩精品xxx| 女厕盗摄一区二区三区| 国产精品久久久久婷婷二区次| 1卡2卡3卡精品视频| 日韩一区二区视频在线| 999精品在线| 日韩精品免费在线播放| 国产欧美激情视频| 美女高潮视频在线看| 国产精品国产三级国产aⅴ入口| 成人综合av网| 中文字幕在线视频第一页| 国产在线成人| 中文字幕不卡在线视频极品| 亚洲天堂av网站| 伊人久久精品| 欧美亚日韩国产aⅴ精品中极品| 国产精品va在线观看无码| 成人18在线| 99久久免费视频.com| 国产欧美日韩高清| 欧美一区二区三区不卡视频| 在线精品一区| 美日韩精品免费观看视频| 欧美偷拍一区二区三区| 精品国产导航| 欧美一级xxx| 黄大色黄女片18第一次| 欧美精品日日操| 五月婷婷激情综合| 国产一二三四五| 成人欧美亚洲| 久久精品人人做人人爽人人| 狠狠色伊人亚洲综合网站色| www.亚洲欧美| 国产精品一二三四区| 成人网在线观看| 中文字幕+乱码+中文乱码91| 久久精品麻豆| 日本一欧美一欧美一亚洲视频| 国产亚洲小视频| 在线免费观看日本欧美爱情大片| www日韩欧美| 日韩福利在线视频| 水蜜桃精品av一区二区| 亚洲视频自拍偷拍| 性猛交娇小69hd| 深爱激情久久| 亚洲天堂av电影| 久久久久久久久久久久久久久| 亚洲va久久| 日韩成人黄色av| 三级黄色片网站| 一本色道久久综合狠狠躁的番外| 日韩精品视频在线免费观看| 你懂的在线观看网站| 欧美91在线| 日韩精品一区二区三区第95| 中文字幕在线看高清电影| 国产欧美日韩在线一区二区| 亚洲色图25p| 男女男精品视频网站| 久久免费大视频| 久久中国妇女中文字幕| 免费麻豆国产一区二区三区四区| 激情成人亚洲| 国产极品jizzhd欧美| 亚洲综合一区中| 国产经典欧美精品| 国产一区二区高清不卡| 免费人成在线观看网站| 中文字幕 久热精品 视频在线| 亚洲亚洲精品三区日韩精品在线视频| 黄色网页在线免费看| 樱桃视频在线观看一区| 天天夜碰日日摸日日澡性色av| 综合另类专区| 欧美精品xxxxbbbb| 在线播放第一页| 亚洲日本三级| 另类视频在线观看| 午夜偷拍福利视频| 日韩综合小视频| 91亚洲va在线va天堂va国| 亚洲第一页视频| 91论坛在线播放| 亚洲精品美女久久7777777| 性欧美1819sex性高清大胸| 天天射综合影视| 国产美女18xxxx免费视频| 极品束缚调教一区二区网站| 亚洲一级黄色片| 久草资源在线视频| 日日欢夜夜爽一区| 国产精品精品软件视频| 成人在线免费看| 亚洲狠狠爱一区二区三区| 国产免费人做人爱午夜视频| 久久伊人精品| 亚洲偷熟乱区亚洲香蕉av| 欧美人妻精品一区二区免费看| 亚洲一区二区三区四区五区午夜| 91亚洲永久免费精品| 日韩精品系列| 亚洲综合久久久| 色国产在线视频| 欧美精品国产白浆久久久久| 理论片在线不卡免费观看| 一级黄色在线视频| 成人综合激情网| 中日韩在线视频| 综合在线影院| 亚洲国产欧美一区二区丝袜黑人 | 成人免费看片'免费看| 美女100%一区| 亚洲国产精久久久久久久| 永久免费看mv网站入口| 日韩精品成人一区二区三区 | 国产av无码专区亚洲av| 中文字幕不卡的av| 国产亚洲精品网站| 波多野结衣欧美| 久久成人一区二区| 中文字幕有码无码人妻av蜜桃| 久久日韩粉嫩一区二区三区 | 成人免费一区二区三区牛牛| 欧美日韩精品福利| 国产又粗又猛又爽又黄的视频小说| 亚洲中字在线| 精品久久一区二区三区蜜桃| 国产区美女在线| 精品久久久久av影院| 手机在线免费看毛片| 精品一区二区三区香蕉蜜桃| 无遮挡亚洲一区| 日本一区二区三区视频在线| 亚洲欧美一区二区激情| 久久精品视频5| 久久免费视频一区| 18禁男女爽爽爽午夜网站免费| 国内自拍欧美| 2020久久国产精品| 男男激情在线| 在线免费视频一区二区| 超薄肉色丝袜一二三| 日本最新不卡在线| 一区二区日本伦理| 久久国际精品| 欧美国产视频日韩| 神马午夜精品95| 色一情一乱一乱一91av| 欧美人与性囗牲恔配| 蜜臀av在线播放一区二区三区| 亚洲欧美精品| 在线高清欧美| 欧美黄色片视频| 日本免费网站在线观看| 大荫蒂欧美视频另类xxxx| 成人免费看aa片| 日韩电影一区二区三区四区| 在线观看欧美一区| 日本在线视频一区二区三区| 国外成人免费在线播放| 日本私人网站在线观看| 欧美性受xxxx| 欧美黑人性猛交xxx| 成人美女视频在线观看| 欧美成人免费高清视频| 99视频精品全部免费在线视频| 亚洲最大av网| 涩涩在线视频| 中文字幕亚洲图片| 亚洲爱情岛论坛永久| 欧美日韩视频免费播放| 国内毛片毛片毛片毛片毛片| 国产精品91xxx| aa在线免费观看| 欧美1级片网站| 国产精品国产精品| 日韩一区二区三区免费| 美日韩在线视频| 欧美日韩免费做爰大片| 884aa四虎影成人精品一区| 1024手机在线视频| 91视频国产资源| 亚洲免费在线播放视频| 亚洲综合国产| 神马午夜伦理影院| 欧美女王vk| 97se亚洲综合| 成人涩涩视频| 97国产在线视频| 国产成人l区| 亚洲精品中文字| 精品国产99久久久久久宅男i| 黄网动漫久久久| 国产1区2区3区4区| 国产亚洲成av人在线观看导航| 欧美午夜精品一区二区| 日本不卡在线视频| 无码人妻精品一区二区三区在线| 99热国内精品| 天堂va久久久噜噜噜久久va| 久久中文资源| 91在线免费视频| 电影一区二区| 青青在线视频一区二区三区| 国产探花在线观看| 久久精品国产清自在天天线| 国产精品影院在线| 亚洲国产日韩一区| 性一交一乱一色一视频麻豆| 欧美精品久久一区| 中文字幕在线观看第二页| 日韩欧美aⅴ综合网站发布| 久久国产在线视频| 亚洲日穴在线视频| 国产视频不卡在线| 久久精品亚洲一区二区三区浴池 | 欧美国产视频在线| 亚洲精品成人无码熟妇在线| 成人精品gif动图一区| 青青草精品在线| 国产美女在线精品| 日韩成人av免费| 老司机午夜精品99久久| 久久精品免费网站| 石原莉奈在线亚洲二区| 少妇高潮喷水久久久久久久久久| 亚洲激情在线| 久艹视频在线免费观看| 国产精品vip| 337p亚洲精品色噜噜狠狠p| 久久久久午夜电影| 黄色高清视频网站| 亚洲一区色图| 欧美美女黄色网| 欧美午夜久久| 国产毛片久久久久久国产毛片| 欧美片第1页综合| 国产一级大片免费看| 亚洲国产精品91| 99久久久精品视频| 激情综合中文娱乐网| 成人免费视频91| 中文日韩欧美| 男女曰b免费视频| 日本欧美久久久久免费播放网| 中文字幕第36页| 国模大尺度一区二区三区| 精产国品一二三区| 成人三级伦理片| a级在线观看视频| 亚洲国产精品激情在线观看| 超碰人人人人人人人| 亚洲素人一区二区| 久久精品亚洲无码| 欧美性猛交视频| 中国一级片黄色一级片黄| 欧美另类videos死尸| 国模人体一区二区| 亚洲欧美色图片| 国产激情视频在线观看| 欧美极品欧美精品欧美视频| 最近在线中文字幕| 国产综合香蕉五月婷在线| 日韩三级不卡| 欧美性大战久久久久| 国产精品成人a在线观看| 2022中文字幕| 久久精品人人| 三日本三级少妇三级99| 99视频精品在线| 精品手机在线视频| 亚洲电影中文字幕在线观看| 久久久精品毛片| 日韩一区二区三区四区五区六区| 天堂国产一区二区三区| 尤物精品国产第一福利三区 | 午夜片欧美伦| 免费一级特黄特色毛片久久看| 日韩国产高清在线| 一区二区在线免费观看视频| 久久久不卡网国产精品一区| 亚洲 欧美 国产 另类| 午夜精品福利一区二区三区av| 免费视频网站在线观看入口| 日韩欧美你懂的| 岛国在线大片| 久久青草精品视频免费观看| 成人a在线观看高清电影| 国产精品yjizz| 99久久夜色精品国产亚洲1000部| 无码中文字幕色专区| 麻豆国产欧美日韩综合精品二区| 一区二区在线视频| 久久精品国产亚洲av麻豆| 国产精品美女久久久久高潮| 国产精品6666| 欧美日本一区二区三区四区| 涩涩视频在线观看免费| 欧美裸体男粗大视频在线观看| 欧美性xxx| 国模精品娜娜一二三区| 先锋资源久久| 91n.com在线观看| 91在线视频网址| 精品视频一区二区在线观看| 欧美久久久久久久久中文字幕| 免费一级毛片在线观看| 91黑丝高跟在线| gogo久久日韩裸体艺术| 天天操天天干天天玩| 日本亚洲免费观看| 免费在线观看成年人视频| 亚洲午夜激情网页| 96日本xxxxxⅹxxx17| 中文字幕亚洲第一| 亚洲日本在线观看视频| 欧美日韩视频在线一区二区观看视频| 国产精品激情| 日韩久久久久久久久久久| 亚洲色大成网站www久久九九| 亚洲天堂中文字幕在线| 中文字幕久久久| 激情亚洲影院在线观看| 欧美精品一区在线发布| 欧美专区18| 久久久久亚洲av无码专区桃色| 婷婷成人激情在线网| 亚洲 精品 综合 精品 自拍| 97精品久久久| 欧美亚洲色图校园春色| 全黄性性激高免费视频| 成人免费视频免费观看| 日本特黄一级片| 亚洲精品国产成人| 擼擼色在线看观看免费| 精品无码久久久久国产| 韩日在线一区| 精品人妻伦一二三区久| 欧美日韩亚洲精品内裤| 青青国产在线| 国产精品久久久久7777婷婷| 欧美综合在线视频观看 | 中文字幕在线官网| 蜜桃麻豆91| 玖玖国产精品视频| 亚洲高潮女人毛茸茸| 欧美精品在线一区二区三区| 成年视频在线观看| 国产成人精品一区二区三区福利| 亚洲一级黄色| 黄色aaa视频| 欧美人妇做爰xxxⅹ性高电影| 麻豆网在线观看| 亚洲最大激情中文字幕| 亚洲激情精品| 在线观看日本中文字幕| 欧美日韩夫妻久久| 91一区二区三区在线| 久久国产精品-国产精品| 日韩综合小视频| 青春草免费视频| 日韩精品中文字幕在线| 欧美一级网址| 97中文字幕在线| 欧美国产精品久久| av无码精品一区二区三区宅噜噜| 97欧美精品一区二区三区| 精品99在线| 自拍偷拍激情视频| 一本大道av伊人久久综合| 91福利国产在线观看菠萝蜜| 精品国产一区二区三区免费| 秋霞影院一区二区| 国产精品suv一区二区69| 亚洲天堂免费在线| 成人国产精品久久| 你懂的av在线| 亚洲丝袜另类动漫二区| 青春草在线观看| 亚洲自拍偷拍一区| 噜噜噜91成人网| 免费人成在线观看| 伊人一区二区三区久久精品| av综合网站| 911福利视频| 色综合中文字幕国产| 日本精品600av| 亚洲国产精品一区在线观看不卡 | 国产一区二区三区精品在线|