一篇文章詳解微服務,讓你知道什麼是微服務,為什麼要使用微服務

2020-09-14 24小時編程自習室

本文將介紹微服務架構和相關的組件,介紹他們是什麼以及為什麼要使用微服務架構和這些組件。本文側重於簡明地表達微服務架構的全局圖景,因此不會涉及具體如何使用組件等細節。

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

最初的需求

幾年前,小明和小皮一起創業做網上超市。小明負責程序開發,小皮負責其他事宜。當時網際網路還不發達,網上超市還是藍海。只要功能實現了就能隨便賺錢。所以他們的需求很簡單,只需要一個網站掛在公網,用戶能夠在這個網站上瀏覽商品、購買商品;另外還需一個管理後臺,可以管理商品、用戶、以及訂單數據。

我們整理一下功能清單:

  • 網站
    • 用戶註冊、登錄
    • 功能商品
    • 展示下單
  • 管理後臺
    • 用戶管理
    • 商品管理
    • 訂單管理

    由於需求簡單,小明左手右手一個慢動作,網站就做好了。管理後臺出於安全考慮,不和網站做在一起,小明右手左手慢動作重播,管理網站也做好了。總體架構圖如下:

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

    隨著業務發展……

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

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

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

    這些活動都需要程序開發的支持。小明拉了同學小紅加入團隊。小紅負責數據分析以及移動端相關開發。小明負責促銷活動相關功能的開發。

    因為開發任務比較緊迫,小明小紅沒有好好規劃整個系統的架構,隨便拍了拍腦袋,決定把促銷管理和數據分析放在管理後臺裡,微信和移動端APP另外搭建。通宵了幾天後,新功能和新應用基本完工。這時架構圖如下:

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

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

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

    是時候做出改變了

    幸好小明和小紅是有追求有理想的好青年。意識到問題後,小明和小紅從瑣碎的業務需求中騰出了一部分精力,開始梳理整體架構,針對問題準備著手改造。

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

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

  • 用戶服務
  • 商品服務
  • 促銷服務
  • 訂單服務
  • 數據分析服務
  • 各個應用後臺只需從這些服務獲取所需的數據,從而刪去了大量冗餘的代碼,就剩個輕薄的控制層和前端。這一階段的架構如下:

    這個階段只是將服務分開了,資料庫依然是共用的,所以一些煙囪式系統的缺點仍然存在:

    1. 資料庫成為性能瓶頸,並且有單點故障的風險。
    2. 數據管理趨向混亂。即使一開始有良好的模塊化設計,隨著時間推移,總會有一個服務直接從資料庫取另一個服務的數據的現象。
    3. 資料庫表結構可能被多個服務依賴,牽一髮而動全身,很難調整。

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

    完全拆分後各個服務可以採用異構的技術。比如數據分析服務可以使用數據倉庫作為持久化層,以便於高效地做一些統計計算;商品服務和促銷服務訪問頻率比較大,因此加入了緩存機制等。

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


    資料庫拆分也有一些問題和挑戰:比如說跨庫級聯的需求,通過服務查詢數據顆粒度的粗細問題等。但是這些問題可以通過合理的設計來解決。總體來說,資料庫拆分是一個利大於弊的。

    微服務架構還有一個技術外的好處,它使整個系統的分工更加明確,責任更加清晰,每個人專心負責為其他人提供更好的服務。在單體應用的時代,公共的業務功能經常沒有明確的歸屬。最後要麼各做各的,每個人都重新實現了一遍;要麼是隨機一個人(一般是能力比較強或者比較熱心的人)做到他負責的應用裡面。在後者的情況下,這個人在負責自己應用之外,還要額外負責給別人提供這些公共的功能——而這個功能本來是無人負責的,僅僅因為他能力較強/比較熱心,就莫名地背鍋(這種情況還被美其名曰能者多勞)。結果最後大家都不願意提供公共的功能。長此以往,團隊裡的人漸漸變得各自為政,不再關心全局的架構設計。

    從這個角度上看,使用微服務架構同時也需要組織結構做相應的調整。所以說做微服務改造需要管理者的支持。

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

    然而……

    沒有銀彈

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

    以往單體應用,排查問題通常是看一下日誌,研究錯誤信息和調用堆棧。而微服務架構整個應用分散成多個服務,定位故障點非常困難。小明一個臺機器一臺機器地查看日誌,一個服務一個服務地手工調用。經過十幾分鐘的查找,小明終於定位到故障點:促銷服務由於接收的請求量太大而停止響應了。其他服務都直接或間接地會調用促銷服務,於是也跟著宕機了。在微服務架構中,一個服務故障可能會產生雪崩效用,導致整個系統故障。其實在節前,小明和小紅是有做過請求量評估的。按照預計,伺服器資源是足以支持節日的請求量的,所以肯定是哪裡出了問題。不過形勢緊急,隨著每一分每一秒流逝的都是白花花的銀子,因此小明也沒時間排查問題,當機立斷在雲上新建了幾臺虛擬機,然後一臺一臺地部署新的促銷服務節點。幾分鐘的操作後,系統總算是勉強恢復正常了。整個故障時間內估計損失了幾十萬的銷售額,三人的心在滴血……

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

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

    • 微服務架構整個應用分散成多個服務,定位故障點非常困難。
    • 穩定性下降。服務數量變多導致其中一個服務出現故障的概率增大,並且一個服務故障可能導致整個系統掛掉。事實上,在大訪問量的生產場景下,故障總是會出現的。
    • 服務數量非常多,部署、管理的工作量很大。
    • 開發方面:如何保證各個服務在持續開發的情況下仍然保持協同合作。
    • 測試方面:服務拆分後,幾乎所有功能都會涉及多個服務。原本單個程序的測試變為服務間調用的測試。測試變得更加複雜。

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

    監控 - 發現故障的徵兆

    在高並發分布式的場景下,故障經常是突然間就雪崩式爆發。所以必須建立完善的監控體系,儘可能發現故障的徵兆。

    微服務架構中組件繁多,各個組件所需要監控的指標不同。比如Redis緩存一般監控佔用內存值、網絡流量,資料庫監控連接數、磁碟空間,業務服務監控並發數、響應延遲、錯誤率等。因此如果做一個大而全的監控系統來監控各個組件是不大現實的,而且擴展性會很差。一般的做法是讓各個組件提供報告自己當前狀態的接口(metrics接口),這個接口輸出的數據格式應該是一致的。然後部署一個指標採集器組件,定時從這些接口獲取並保持組件狀態,同時提供查詢服務。最後還需要一個UI,從指標採集器查詢各項指標,繪製監控界面或者根據閾值發出告警。

    大部分組件都不需要自己動手開發,網絡上有開源組件。小明下載了RedisExporter和MySQLExporter,這兩個組件分別提供了Redis緩存和MySQL資料庫的指標接口。微服務則根據各個服務的業務邏輯實現自定義的指標接口。然後小明採用Prometheus作為指標採集器,Grafana配置監控界面和郵件告警。這樣一套微服務監控系統就搭建起來了:

    定位問題 - 鏈路跟蹤

    在微服務架構下,一個用戶的請求往往涉及多個內部服務調用。為了方便定位問題,需要能夠記錄每個用戶請求時,微服務內部產生了多少服務調用,及其調用關係。這個叫做鏈路跟蹤。

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

    圖片來自Istio文檔

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

    要實現鏈路跟蹤,每次服務調用會在HTTP的HEADERS中記錄至少記錄四項數據:

    • traceId:traceId標識一個用戶請求的調用鏈路。具有相同traceId的調用屬於同一條鏈路。
    • spanId:標識一次服務調用的ID,即鏈路跟蹤的節點ID。
    • parentId:父節點的spanId。
    • requestTime & responseTime:請求時間和響應時間。

    另外,還需要調用日誌收集與存儲的組件,以及展示鏈路調用的UI組件。

    以上只是一個極簡的說明,關於鏈路跟蹤的理論依據可詳見Google的Dapper

    了解了理論基礎後,小明選用了Dapper的一個開源實現Zipkin。然後手指一抖,寫了個HTTP請求的攔截器,在每次HTTP請求時生成這些數據注入到HEADERS,同時異步發送調用日誌到Zipkin的日誌收集器中。這裡額外提一下,HTTP請求的攔截器,可以在微服務的代碼中實現,也可以使用一個網絡代理組件來實現(不過這樣子每個微服務都需要加一層代理)。

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

    分析問題 - 日誌分析

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

    因此,在應用規模變大時,我們需要一個日誌的「搜尋引擎」。以便於能準確的找到想要的日誌。另外,數據源一側還需要收集日誌的組件和展示結果的UI組件:

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

    • Elasticsearch:搜尋引擎,同時也是日誌的存儲。
    • Logstash:日誌採集器,它接收日誌輸入,對日誌進行一些預處理,然後輸出到Elasticsearch。
    • Kibana:UI組件,通過Elasticsearch的API查找數據並展示給用戶。

    最後還有一個小問題是如何將日誌發送到Logstash。一種方案是在日誌輸出的時候直接調用Logstash接口將日誌發送過去。這樣一來又(咦,為啥要用「又」)要修改代碼……於是小明選用了另一種方案:日誌仍然輸出到文件,每個服務裡再部署個Agent掃描日誌文件然後輸出給Logstash。

    網關 - 權限控制,服務治理

    拆分成微服務後,出現大量的服務,大量的接口,使得整個調用關係亂糟糟的。經常在開發過程中,寫著寫著,忽然想不起某個數據應該調用哪個服務。或者寫歪了,調用了不該調用的服務,本來一個只讀的功能結果修改了數據……

    為了應對這些情況,微服務的調用需要一個把關的東西,也就是網關。在調用者和被調用者中間加一層網關,每次調用時進行權限校驗。另外,網關也可以作為一個提供服務接口文檔的平臺。

    使用網關有一個問題就是要決定在多大粒度上使用:最粗粒度的方案是整個微服務一個網關,微服務外部通過網關訪問微服務,微服務內部則直接調用;最細粒度則是所有調用,不管是微服務內部調用或者來自外部的調用,都必須通過網關。折中的方案是按照業務領域將微服務分成幾個區,區內直接調用,區間通過網關調用。

    由於整個網上超市的服務數量還不算特別多,小明採用的最粗粒度的方案:

    服務註冊於發現 - 動態擴容

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

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

    冗餘的一個問題是使用幾個冗餘?這個問題在時間軸上並沒有一個切確的答案。根據服務功能、時間段的不同,需要不同數量的實例。比如在平日裡,可能4個實例已經夠用;而在促銷活動時,流量大增,可能需要40個實例。因此冗餘數量並不是一個固定的值,而是根據需要實時調整的。

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

    1. 部署新實例
    2. 將新實例註冊到負載均衡或DNS上

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

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

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

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

    熔斷、服務降級、限流

    • 熔斷

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

    圖片來自《微服務設計》

    • 服務降級

    當下遊服務停止工作後,如果該服務並非核心業務,則上遊服務應該降級,以保證核心業務不中斷。比如網上超市下單界面有一個推薦商品湊單的功能,當推薦模塊掛了後,下單功能不能一起掛掉,只需要暫時關閉推薦功能即可。

    • 限流

    一個服務掛掉後,上遊服務或者用戶一般會習慣性地重試訪問。這導致一旦服務恢復正常,很可能因為瞬間網絡流量過大又立刻掛掉,在棺材裡重複著仰臥起坐。因此服務需要能夠自我保護——限流。限流策略有很多,最簡單的比如當單位時間內請求數過多時,丟棄多餘的請求。另外,也可以考慮分區限流。僅拒絕來自產生大量請求的服務的請求。例如商品服務和訂單服務都需要訪問促銷服務,商品服務由於代碼問題發起了大量請求,促銷服務則只限制來自商品服務的請求,來自訂單服務的請求則正常響應。

    測試

    微服務架構下,測試分為三個層次:

    1. 端到端測試:覆蓋整個系統,一般在用戶界面進行測試。
    2. 服務測試:針對服務接口進行測試。
    3. 單元測試:針對代碼單元進行測試。

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

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

    服務測試的難度在於服務會經常依賴一些其他服務。這個問題可以通過Mock Server解決:

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

    微服務框架

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

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

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

    另一條路 - Service Mesh

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

    Sidecar不會產生額外網絡成本。Sidecar會和微服務節點部署在同一臺主機上並且共用相同的虛擬網卡。所以sidecar和微服務節點的通信實際上都只是通過內存拷貝實現的。

    圖片來自:Pattern: Service Mesh

    Sidecar只負責網絡通信。還需要有個組件來統一管理所有sidecar的配置。在Service Mesh中,負責網絡通信的部分叫數據平面(data plane),負責配置管理的部分叫控制平面(control plane)。數據平面和控制平面構成了Service Mesh的基本架構。

    圖片來自:Pattern: Service Mesh

    Sevice Mesh相比於微服務框架的優點在於它不侵入代碼,升級和維護更方便。它經常被詬病的則是性能問題。即使迴環網絡不會產生實際的網絡請求,但仍然有內存拷貝的額外成本。另外有一些集中式的流量處理也會影響性能。

    結束、也是開始

    微服務不是架構演變的終點。往細走還有Serverless、FaaS等方向。另一方面也有人在唱合久必分分久必合,重新發現單體架構……

    不管怎樣,微服務架構的改造暫時告一段落了。小明滿足地摸了摸日益光滑的腦袋,打算這個周末休息一下約小紅喝杯咖啡。


    文章來源:博客園

    原文作者:古霜卡比

    原文連結:https://www.cnblogs.com/skabyy/p/11396571.html

    支持原創!尊重原創!轉發註明出處!

    相關焦點

    • 詳解微服務架構(一):什麼是微服務
      解析微服務架構系列文章將分幾篇描述微服務的定義、特點、應用場景、企業集成架構的演進以及微服務轉型思路和技術決策考慮等內容,並以IBM技術為例介紹如何實現微服務架構轉型。為什麼需要微服務架構「微服務」架構是近期軟體應用領域非常熱門的概念。
    • 微服務還沒徹底普及,宏服務又要來了?
      當Uber公司某支團隊宣布從微服務轉向宏服務時,腦子瞬時飄來幾個字「某種馬」。微服務還沒吃透呢,宏服務又來了,聽到宏服務這個名字,腦海中好像是聽說過,但是完全不了解。於是各種搜索,各種網站的信息翻了一遍。今天的主要目的是介紹為什麼要使用宏服務?
    • 是什麼讓你這麼嚮往微服務?5分鐘了解微服務的本質
      有不少人經常問我,「最近想換個工作,不會微服務怎麼辦?」,「我們公司新立的那個項目不是微服務架構,好失望!」,「我希望下家公司使用微服務」……這樣的話聽到的太多了,但我每次問為什麼你這麼嚮往使用微服務呢,對方給出的回答總是含糊不清,都是諸如「反正其他人都在用,覺得高大上」這類的回答,所以我覺得有必要來寫一篇文章來澄清下微服務的本質了。
    • 2021升級版微服務教程—為什麼會有微服務?什麼是SpringCloud?
      2021升級版SpringCloud教程從入門到實戰精通「H版&alibaba&鏈路追蹤&日誌&事務&鎖」教程全目錄「含視頻」:https://gitee.com/bingqilinpeishenme/Java-Wiki微服務基本概念架構的演變為什麼會有微服務?
    • 精讀| 什麼是微服務架構?
      你考慮過嗎?什麼是微服務,為什麼越來越多的企業,為了使自己構建的應用滿足客戶的期望,而和微服務架構進行整合呢?wonder 想知道microservice 微服務integrate with 使與...整合keep up with 跟上expectation 期望02緊接著,作者告訴我們閱讀完文章後,可以獲取到哪些關於微服務的知識。
    • 阿里微服務布道師:詳解微服務架構設計
      微服務也指一種種鬆耦合的、有一定的有界上下文的面向服務架構。也就是說,如果每個服務都要同時修改,那麼它們就不是微服務,因為它們緊耦合在一起;如果你需要掌握一個服務太多的上下文場景使用條件,那麼它就是一個有上下文邊界的服務,這個定義來自DDD領域驅動設計。
    • 微服務為什麼一定要選spring cloud?
      現如今微服務架構十分流行,而採用微服務構建系統也會帶來更清晰的業務劃分和可擴展性。同時,支持微服務的技術棧也是多種多樣的,本系列文章主要介紹這些技術中的翹楚——Spring Cloud。這是序篇,主要講述我們為什麼選擇Spring Cloud和它的技術概要。1.
    • 概念篇:一篇文章讓你徹底搞明白什麼是微服務(值得收藏)
      前言到底什麼是微服務?為什麼要用微服務?微服務主要來做一些什麼?微服務有哪些優勢?什麼樣的服務屬於微服務?本文所有資料來源網絡,僅供參考。一、微服務介紹1.什麼是微服務在介紹微服務時,首先得先理解什麼是微服務,顧名思義,微服務得從兩個方面去理解,什麼是"微"、什麼是"服務",微,狹義來講就是體積小、著名的"2 pizza 團隊"很好的詮釋了這一解釋(2 pizza 團隊最早是
    • AliP9整理出微服務筆記:Spring微服務不止架構和設計
      通過一系列示例(包括一個旅遊業的案例研究),文中闡述了微服務架構的實現,涉及Spring框架、Spring Boot和Spring Cloud. 這些都是用於開發和部署大規模可擴展微服務的強大且久經考驗的工具。本文基於Spring框架的最新規範編寫。藉助本書,你可以快速構建網際網路級現代Java應用。
    • 你從未見過的,最全微服務實戰詳解,誰說微服務架構模式只有6種
      微服務架構是一項在雲中部署應用和服務的新技術。不需要像普通服務那樣成為一種獨立的功能或者獨立的資源。定義中稱,微服務是需要與業務能力相匹配,這種說法完全正確。不幸的是,仍然意味著,如果能力模型粒度的設計是錯誤的,那麼,我們就必須付出很多代價。如果你閱讀了這整篇文章所包含的文檔,你會發現,其中的指導建議是非常實用的。
    • Spring Cloud 微服務入門教程(一):微服務介紹
      前言我的個人博客網站一直堅持每年一次大更新,但這次我決定不更新了,因為再更新就是使用微服務了,一個小網站用微服務架構就有點殺雞用牛刀了,而且維護起來比較費時費力。所以直接寫成教程文章就不再大動幹戈的去重寫我的博客了。
    • 被微服務轟炸?莫怕!耗時35天整出的「微服務學習教程」送你
      又被微服務轟炸?莫慌莫怕!小編連續25天,整出這份最新最全「學習教程」送你!軟體來繪畫所有的導圖,不能直接上傳在文章裡,但都有以截圖的形式進行展示。整體的內容知識點也是偏多的,截圖是截取不完的,所以請各位朋友注意:若是需要下載整個微服務架構的導圖(總+分),便可直接私信小編關鍵詞【微服務】就行!
    • 放棄微服務,改用宏服務,Uber 這波什麼操作?
      一向是微服務積極分子的 Uber 為什麼突然改用宏服務了?以「簡單」著稱的微服務為什麼又變得難以維護了呢? 1 Uber 支付團隊放棄微服務,轉用宏服務 4 月 6 日,Uber 支付體驗平臺的工程經理 Gergely Orosz 發布推文表示其團隊的架構方向已經發生了變化,放棄微服務,轉而使用宏服務。
    • 微服務架構一直火,為什麼服務化要搞懂?
      微服務架構,這 5 年左右一直被認可,是軟體架構的未來方向。需要大家理解的是,為什麼需要服務化。比如微服務架構對企業來說,帶來什麼價值?有啥弊端?這裡淺談一下微服務架構,主要還是在理解 Why :為什麼需要服務化?
    • soa和微服務的區別
      這種架構將系統的整合點推移到了服務之間的接口,因此這些服務的接口需要進行良好的定義,在系統中也要對服務級別達成一致,並且還需要定義其他的非功能性需求。 在目前來看,微服務還是一種相對較新的技術,架構師與開發者們通常所使用的一些輔助性工具也還處於發展階段,以上所提及的這些問題可能遲早會得到解決。
    • 微服務治理實踐:服務契約
      本文是《微服務治理實踐》系列篇的第四篇文章,主要分享Spring Cloud微服務框架下的服務契約。第一篇:《微服務治理解密》第二篇:《微服務治理實踐:服務查詢》第三篇:《微服務治理實踐:金絲雀發布》在詳細講述服務契約之前,先給大家講一個場景。
    • 進行微服務治理,先要對微服務進行度量
      要管得到,必須先看得到!要對微服務進行治理,先要對微服務進行度量。根據微服務的生命周期,可以將服務度量分為服務開發質量度量、服務測試質量度量、服務運維質量度量和服務線上性能度量四大部分。在微服務架構下通常會採用小團隊、敏捷的開發模式,使用特定的需求和研發過程管理工具對業務需求、研發用例及研發進度進行全程管理。
    • 讀懂這篇文章,就掌握微服務測試核心了
      最近我寫了四篇關於微服務測試的文章,本文介紹微服務測試的核心點,前面三篇分別介紹了:入門微服務必須了解的概念 微服務負載的重要性 微服務如何查詢應用日誌 相信這幾篇文章一定會幫助大家在微服務測試領域實現從0到1的突破!
    • 並不是每個公司的每個項目都適合微服務 | 微服務雜談
      對於我自己來說,從15年就開始關注這一塊,看過馬丁.福勒最開始的關於微服務的論文、也看過不少對微服務的論證的英文文章和書,也研究過Spring Cloud、Sofa等開源實現以及Service mesh。考慮到我們公司研發團隊人力不足、基礎設施不完善,當初是沒有推行微服務的。但隨著看到上述的那種簡歷越來越多,有時候我也會疑問:難道真的不用微服務就落後了嗎?
    • 阿里微服務技術精髓全整合在這份「限量手冊」裡,服了
      微服務關於微服務,相關的博文有太多太多了,它的概念我就這裡就不再多說了我們先來聊一聊它的優點與正在面臨的挑戰,以及為什麼選擇Spring Cloud來構建微服務的原因。下面要介紹的這一份阿里內部手冊就是從微服務架構概念出發,結合Spring Cloud的解決方案,深入淺出地剖析了其在構建微服務架構中所需的各個基礎設施和技術要點,非常適合正在或打算實施微服務的團隊作為參考手冊。