微服務架構的優勢與不足


上篇文章給大家簡單介紹了一下微處理架構,現在我來為大家分析微服務架構的優勢與不足。

 

微處理架構——處理復雜事物

許多公司,比如Amazon、eBay和NetFlix,通過采用微處理結構模式解決了上述問題。其思路不是開發一個巨大的單體式的應用,而是將應用分解為小的、互相連接的微服務。

一個微服務一般完成某個特定的功能,比如下單管理、客戶管理等等。每一個微服務都是微型六角形應用,都有自己的業務邏輯和適配器。一些微服務還 會發布API給其它微服務和應用客戶端使用。其它微服務完成一個Web UI,運行時,每一個實例可能是一個雲VM或者是Docker容器。

比如,一個前面描述系統可能的分解如下:

每一個應用功能區都使用微服務完成,另外,Web應用會被拆分成一系列簡單的Web應用(比如一個對乘客,一個對出租車駕駛員)。這樣的拆分對於不同用戶、設備和特殊應用場景部署都更容易。

每一個后台服務開放一個REST API,許多服務本身也采用了其它服務提供的API。比如,駕駛員管理使用了告知駕駛員一個潛在需求的通知服務。UI服務激活其它服務來更新Web頁面。所有服務都是采用異步的,基於消息的通訊。微服務內部機制將會在后續系列中討論。

一些REST API也對乘客和駕駛員采用的移動應用開放。這些應用並不直接訪問后台服務,而是通過API Gateway來傳遞中間消息。API Gateway負責負載均衡、緩存、訪問控制、API 計費監控等等任務,可以通過NGINX方便實現,后續文章將會介紹到API Gateway。

·微服務架構模式在上圖中對應於代表可擴展Scale Cube的Y軸,這是一個在《The Art of Scalability》書中描述過的三維擴展模型。另外兩個可擴展軸,X軸由負載均衡器后端運行的多個應用副本組成,Z軸是將需求路由到相關服務。

應用基本可以用以上三個維度來表示,Y軸代表將應用分解為微服務。運行時,X軸代表運行多個隱藏在負載均衡器之后的實例,提供吞吐能力。一些應用可能還是用Z軸將服務分區。下面的圖演示行程管理服務如何部署在運行於AWS EC2上的Docker上。

運行時,行程管理服務由多個服務實例構成。每一個服務實例都是一個Docker容器。為了保證高可用,這些容器一般都運行在多個雲VM上。服務實例前是 一層諸如NGINX的負載均衡器,他們負責在各個實例間分發請求。負載均衡器也同時處理其它請求,例如緩存、權限控制、API統計和監控。

這種微服務架構模式深刻影響了應用和數據庫之間的關系,不像傳統多個服務共享一個數據庫,微服務架構每個服務都有自己的數據庫。另外,這種思路也影響到了企業級數據模式。同時,這種模式意味着多份數據,但是,如果你想獲得微服務帶來的好處,每個服務獨有一個數據庫是必須的,因為這種架構需要這種松耦合。下面的圖演示示例應用數據庫架構。

每種服務都有自己的數據庫,另外,每種服務可以用更適合自己的數據庫類型,也被稱作多語言一致性架構。比如,駕駛員管理(發現哪個駕駛員更靠近乘客),必須使用支持地理信息查詢的數據庫。

表面上看來,微服務架構模式有點像SOA,他們都由多個服務構成。但是,可以從另外一個角度看此問題,微服務架構模式是一個不包含Web服務 (WS-)和ESB服務的SOA。微服務應用樂於采用簡單輕量級協議,比如REST,而不是WS-,在微服務內部避免使用ESB以及ESB類似功能。微服 務架構模式也拒絕使用canonical schema等SOA概念。

微服務架構的好處

微服務架構模式有很多好處。首先,通過分解巨大單體式應用為多個服務方法解決了復雜性問題。在功能不變的情況下,應用被分解為多個可管理的分支 或服務。每個服務都有一個用RPC-或者消息驅動API定義清楚的邊界。微服務架構模式給采用單體式編碼方式很難實現的功能提供了模塊化的解決方案,由 此,單個服務很容易開發、理解和維護。

第二,這種架構使得每個服務都可以有專門開發團隊來開發。開發者可以自由選擇開發技術,提供API服務。當然,許多公司試圖避免混亂,只提供某 些技術選擇。然后,這種自由意味着開發者不需要被迫使用某項目開始時采用的過時技術,他們可以選擇現在的技術。甚至於,因為服務都是相對簡單,即使用現在 技術重寫以前代碼也不是很困難的事情。

第三,微服務架構模式是每個微服務獨立的部署。開發者不再需要協調其它服務部署對本服務的影響。這種改變可以加快部署速度。UI團隊可以采用AB測試,快速的部署變化。微服務架構模式使得持續化部署成為可能。

最后,微服務架構模式使得每個服務獨立擴展。你可以根據每個服務的規模來部署滿足需求的規模。甚至於,你可以使用更適合於服務資源需求的硬件。 比如,你可以在EC2 Compute Optimized instances上部署CPU敏感的服務,而在EC2 memory-optimized instances上部署內存數據庫。

微服務架構的不足

Fred Brooks在30Year前寫道,“there are no silver bullets”,像任何其它科技一樣,微服務架構也有不足。其中一個跟他的名字類似,『微服務』強調了服務大小,實際上,有一些開發者鼓吹建立稍微大一 些的,10-100 LOC服務組。盡管小服務更樂於被采用,但是不要忘了這只是終端的選擇而不是最終的目的。微服務的目的是有效的拆分應用,實現敏捷開發和部署。

另外一個主要的不足是,微服務應用是分布式系統,由此會帶來固有的復雜性。開發者需要在RPC或者消息傳遞之間選擇並完成進程間通訊機制。更甚 於,他們必須寫代碼來處理消息傳遞中速度過慢或者不可用等局部失效問題。當然這並不是什么難事,但相對於單體式應用中通過語言層級的方法或者進程調用,微 服務下這種技術顯得更復雜一些。

另外一個關於微服務的挑戰來自於分區的數據庫架構。商業交易中同時給多個業務分主體更新消息很普遍。這種交易對於單體式應用來說很容易,因為只 有一個數據庫。在微服務架構應用中,需要更新不同服務所使用的不同的數據庫。使用分布式交易並不一定是好的選擇,不僅僅是因為CAP理論,還因為今天高擴 展性的NoSQL數據庫和消息傳遞中間件並不支持這一需求。最終你不得不使用一個最終一致性的方法,從而對開發者提出了更高的要求和挑戰。

測試一個基於微服務架構的應用也是很復雜的任務。比如,采用流行的Spring Boot架構,對一個單體式web應用,測試它的REST API,是很容易的事情。反過來,同樣的服務測試需要啟動和它有關的所有服務(至少需要這些服務的stubs)。再重申一次,不能低估了采用微服務架構帶 來的復雜性。

另外一個挑戰在於,微服務架構模式應用的改變將會波及多個服務。比如,假設你在完成一個案例,需要修改服務A、B、C,而A依賴B,B依賴C。 在單體式應用中,你只需要改變相關模塊,整合變化,部署就好了。對比之下,微服務架構模式就需要考慮相關改變對不同服務的影響。比如,你需要更新服務C, 然后是B,最后才是A,幸運的是,許多改變一般只影響一個服務,而需要協調多服務的改變很少。

部署一個微服務應用也很復雜,一個分布式應用只需要簡單在復雜均衡器后面部署各自的服務器就好了。每個應用實例是需要配置諸如數據庫和消息中間件等基礎服務。相對比,一個微服務應用一般由大批服務構成。例如,根據Adrian Cockcroft,NetFlix 有大約600個服務。每個服務都有多個實例。這就造成許多需要配置、部署、擴展和監控的部分,除此之外,你還需要完成一個服務發現機制(后續文章中發 表),以用來發現與它通訊服務的地址(包括服務器地址和端口)。傳統的解決問題辦法不能用於解決這么復雜的問題。接續而來,成功部署一個微服務應用需要開 發者有足夠的控制部署方法,並高度自動化。

一種自動化方法是使用PaaS服務,例如Cloud Foundry。 PaaS給開發者提供一個部署和管理微服務的簡單方法,它把所有這些問題都打包內置解決了。同時,配置PaaS的系統和網絡專家可以采用最佳實踐和策略來 簡化這些問題。另外一個自動部署微服務應用的方法是開發對於你來說最基礎的PaaS系統。一個典型的開始點是使用一個集群化方案,比如配合Docker使 用Mesos或者Kubernetes。后面的系列我們會看看如何基於軟件部署方法例如NGINX,可以方便的在微服務層面提供緩存、權限控制、API統 計和監控。

總結

構建復雜的應用真的是非常困難。單體式的架構更適合輕量級的簡單應用。如果你用它來開發復雜應用,那真的會很糟糕。微服務架構模式可以用來構建復雜應用,當然,這種架構模型也有自己的缺點和挑戰。

在后續的博客中,我會深入探索微服務架構模式,並討論諸如服務發現、服務部署選擇和如何分解一個分布式應用為多個服務的策略。

-----------------------------------------------------------------------------------

完整的項目源碼   歡迎大家一起學習研究相關技術,源碼獲取請加求求:2670716182


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM