微服務技術架構深入解析_第1頁
微服務技術架構深入解析_第2頁
微服務技術架構深入解析_第3頁
微服務技術架構深入解析_第4頁
已閱讀5頁,還剩8頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、 微服務技術架構深入解析 導語:微服務架構如何與更廣泛的軟件架構概念相結合?什么是服務?服務的規(guī)模有多重要?為了回答這些問題,我們需要退后一步,看看軟件架構的含義。軟件的架構是一種抽象的結構,它由軟件的各個組成部分和這些部分之間的依賴關系構成。正如你將在本文中看到的,軟件的架構是多維的,因此有多種方法可以對其進行描述。架構很重要的原因是它決定了應用程序的質量屬性或能力。傳統(tǒng)上,架構的目標是可擴展性、可靠性和安全性。但是今天,該架構能夠快速安全地交付軟件,這一點非常重要。你將了解微服務架構是一種架構風格,可為應用程序提供更高的可維護性、可測試性和可部署性。我將通過描述軟件架構的概念及其重要性來開

2、始本文。接下來,我將討論架構風格的概念。然后我將微服務架構定義為特定的架構風格。讓我們從理解軟件架構的概念開始。1軟件架構是什么,為什么它如此重要架構顯然很重要。至少有兩個專門討論該主題的會議:OReilly的軟件架構會議和SATURN會議。許多開發(fā)人員的目標是成為一名架構師。但什么是架構,為什么它如此重要?為了回答這個問題,我首先定義術語軟件架構的含義。之后,我將討論應用程序的架構是多維的,并使用一組視圖或藍圖進行描述。然后我將強調軟件架構的重要性,因為它對應用程序的質量屬性有顯著的影響。軟件架構的定義軟件架構有很多定義。例如,維基百科上列舉了大量的定義。我最喜歡的定義來自卡耐基梅隆大學軟件

3、工程研究所的Len Bass及其同事,他們在使軟件架構成為一門學科方面發(fā)揮了關鍵作用。他們定義的軟件架構如下:計算機系統(tǒng)的軟件架構是構建這個系統(tǒng)所需要的一組結構,包括軟件元素、它們之間的關系以及兩者的屬性。這顯然是一個非常抽象的定義。但其實質是應用程序的架構是將軟件分解為元素(element)和這些元素之間的關系(relation)。由于以下兩個原因,分解很重要:它促進了勞動和知識的分工。它使具有特定專業(yè)知識的人們(或多個團隊)能夠就應用程序高效地協(xié)同工作。它定義了軟件元素的交互方式。將軟件分解成元素以及定義這些元素之間的關系,決定了軟件的能力。軟件架構的4+1視圖模型從更具體的角度而言,應用

4、程序的架構可以從多個視角來看,就像建筑架構,一般有結構、管線、電氣等多個架構視角。Phillip Krutchen在他經典的論文Architectural Blueprints The 4+1 View Model of Software Architecture中提出了軟件架構的4+1視圖。圖1展示的這套視圖定義了四個不同的軟件架構視圖,每一個視圖都只描述架構的一個特定方面。每個視圖包括一些特定的軟件元素和它們相互之間的關系。圖14+1視圖模型使用四個視圖描述應用程序的架構,并顯示每個視圖中的元素如何協(xié)作處理請求的場景每個視圖的目的如下:邏輯視圖:開發(fā)人員創(chuàng)建的軟件元素。在面向對象的語言中,

5、這些元素是類和包。它們之間的關系是類和包之間的關系,包括繼承、關聯(lián)和依賴。實現(xiàn)視圖:構建編譯系統(tǒng)的輸出。此視圖由表示打包代碼的模塊和組件組成,組件是由一個或多個模塊組成的可執(zhí)行或可部署單元。在Java中,模塊是JAR文件,組件通常是WAR文件或可執(zhí)行JAR文件。它們之間的關系包括模塊之間的依賴關系以及組件和模塊之間的組合關系。進程視圖:運行時的組件。每個元素都是一個進程,進程之間的關系代表進程間通信。部署視圖:進程如何映射到機器。此視圖中的元素由(物理或虛擬)計算機和進程組成。機器之間的關系代表網絡。該視圖還描述了進程和機器之間的關系。除了這四個視圖以外,4+1中的+1是指場景,它負責把視圖串

6、聯(lián)在一起。每個場景負責描述在一個視圖中的多個架構元素如何協(xié)作,以完成一個請求。例如,在邏輯視圖中的場景,展現(xiàn)了類是如何協(xié)作的。同樣,在進程視圖中的場景,展現(xiàn)了進程是如何協(xié)作的。4+1視圖是描述應用程序架構的絕佳方式。每一個視圖都描述了架構的一個重要側面。場景把視圖中的元素如何協(xié)作串聯(lián)在一起。現(xiàn)在我們來看看為什么架構是如此重要。為什么架構如此重要應用程序有兩個層面的需求。第一類是功能性需求,這些需求決定一個應用程序做什么。這些通常都包含在用例(use case)或者用戶故事(user story)中。應用的架構其實跟這些功能性需求沒什么關系。功能性需求可以通過任意的架構來實現(xiàn),甚至是非常糟糕的大

7、泥球架構。架構的重要性在于,它幫助應用程序滿足了第二類需求:非功能性需求。我們把這類需求也稱之為質量屬性需求,或者簡稱為“能力”。這些非功能性需求決定一個應用程序在運行時的質量,比如可擴展性和可靠性。它們也決定了開發(fā)階段的質量,包括可維護性、可測試性、可擴展性和可部署性。為應用程序所選擇的架構將決定這些質量屬性。2什么是架構的風格在物理世界中,建筑物的建筑通常遵循特定的風格,例如維多利亞式、美國工匠式或裝飾藝術式。每種風格都是一系列設計決策,限制了建筑的特征和建筑材料。建筑風格的概念也適用于軟件。David Garlan和Mary Shaw這兩位軟件架構學科的先驅定義了如下架構風格:因此,架構

8、風格根據(jù)結構組織模式定義了一系列此類系統(tǒng)。更具體地說,架構風格確定可以在該風格的實例中使用的組件和連接器的詞匯表,以及關于如何組合它們的一組約束。特定的架構風格提供了有限的元素(組件)和關系(連接器),你可以從中定義應用程序架構的視圖。應用程序通常使用多種架構風格的組合。例如,在本節(jié)的后面,我將描述單體架構是如何將實現(xiàn)視圖構造為單個(可執(zhí)行與可部署)組件的架構樣式。微服務架構將應用程序構造為一組松散耦合的服務。分層式架構風格架構的典型例子是分層架構。分層架構將軟件元素按“層”的方式組織。每個層都有明確定義的職責。分層架構還限制了層之間的依賴關系。每一層只能依賴于緊鄰其下方的層(如果嚴格分層)或

9、其下面的任何層??梢詫⒎謱蛹軜嫅糜谇懊嬗懻摰乃膫€視圖中的任何一個。流行的三層架構是應用于邏輯視圖的分層架構。它將應用程序的類組織到以下層中:表現(xiàn)層:包含實現(xiàn)用戶界面或外部API的代碼。業(yè)務邏輯層:包含業(yè)務邏輯。數(shù)據(jù)持久化層:實現(xiàn)與數(shù)據(jù)庫交互的邏輯。分層架構是架構風格的一個很好的例子,但它確實有一些明顯的弊端:單個表現(xiàn)層:它無法展現(xiàn)應用程序可能不僅僅由單個系統(tǒng)調用的事實。單一數(shù)據(jù)持久化層:它無法展現(xiàn)應用程序可能與多個數(shù)據(jù)庫進行交互的事實。將業(yè)務邏輯層定義為依賴于數(shù)據(jù)持久化層:理論上,這樣的依賴性會妨礙你在沒有數(shù)據(jù)庫的情況下測試業(yè)務邏輯。此外,分層架構錯誤地表示了精心設計的應用程序中的依賴關系。

10、業(yè)務邏輯通常定義數(shù)據(jù)訪問方法的接口或接口庫。數(shù)據(jù)持久化層則定義了實現(xiàn)存儲庫接口的DAO類。換句話說,依賴關系與分層架構所描述的相反。讓我們看一下克服這些弊端的替代架構:六邊形架構。關于架構風格的六邊形六邊形架構是分層架構風格的替代品。如圖2-2所示,六邊形架構風格選擇以業(yè)務邏輯為中心的方式組織邏輯視圖。應用程序具有一個或多個入站適配器,而不是表示層,它通過調用業(yè)務邏輯來處理來自外部的請求。同樣,應用程序具有一個或多個出站適配器,而不是數(shù)據(jù)持久化層,這些出站適配器由業(yè)務邏輯調用并調用外部應用程序。此架構的一個關鍵特性和優(yōu)點是業(yè)務邏輯不依賴于適配器。相反,各種適配器都依賴業(yè)務邏輯。圖2六邊形架構的

11、一個示例,它由業(yè)務邏輯和一個或多個與外部系統(tǒng)通信的適配器組成。業(yè)務邏輯具有一個或多個端口。處理來自外部系統(tǒng)請求的入站適配器調用入站端口。出站適配器實現(xiàn)出站端口,并調用外部系統(tǒng)業(yè)務邏輯具有一個或多個端口(port)。端口定義了一組操作,關于業(yè)務邏輯如何與外部交互。例如,在Java中,端口通常是Java接口。有兩種端口:入站和出站端口。入站端口是業(yè)務邏輯公開的API,它使外部應用程序可以調用它。入站端口的一個實例是服務接口,它定義服務的公共方法。出站端口是業(yè)務邏輯調用外部系統(tǒng)的方式。出站端口的一個實例是存儲庫接口,它定義數(shù)據(jù)訪問操作的集合。業(yè)務邏輯的周圍是適配器。與端口一樣,有兩種類型的適配器:入

12、站和出站。入站適配器通過調用入站端口來處理來自外部世界的請求。入站適配器的一個實例是Spring MVC Controller,它實現(xiàn)一組REST接口(endpoint)或一組Web頁面。另一個實例是訂閱消息的消息代理客戶端。多個入站適配器可以調用相同的入站端口。出站適配器實現(xiàn)出站端口,并通過調用外部應用程序或服務處理來自業(yè)務邏輯的請求。出站適配器的一個實例是實現(xiàn)訪問數(shù)據(jù)庫的操作的數(shù)據(jù)訪問對象(DAO)類。另一個實例是調用遠程服務的代理類。出站適配器也可以發(fā)布事件。六邊形架構風格的一個重要好處是它將業(yè)務邏輯與適配器中包含的表示層和數(shù)據(jù)訪問層的邏輯分離開來。業(yè)務邏輯不依賴于表示層邏輯或數(shù)據(jù)訪問層

13、邏輯。由于這種分離,單獨測試業(yè)務邏輯要容易得多。另一個好處是它更準確地反映了現(xiàn)代應用程序的架構??梢酝ㄟ^多個適配器調用業(yè)務邏輯,每個適配器實現(xiàn)特定的API或用戶界面。業(yè)務邏輯還可以調用多個適配器,每個適配器調用不同的外部系統(tǒng)。六邊形架構是描述微服務架構中每個服務的架構的好方法。分層架構和六邊形架構都是架構風格的實例。每個都定義了架構的構建塊(元素),并對它們之間的關系施加了約束。六邊形架構和分層架構(三層架構)構成了軟件的邏輯視圖。現(xiàn)在讓我們將微服務架構定義為構成軟件的實現(xiàn)視圖的架構風格。2.1.3微服務架構是一種架構風格前面已經討論過4+1視圖模型和架構風格,所以現(xiàn)在可以開始定義單體架構和微

14、服務架構。它們都是架構風格。單體架構是一種架構風格,它的實現(xiàn)視圖是單個組件:單個可執(zhí)行文件或WAR文件。這個定義并沒有說明其他的視圖。例如,單體應用程序可以具有六邊形架構風格的邏輯視圖。模式:單體架構將應用程序構建為單個可執(zhí)行和可部署組件。請參閱:http:/microservices.io/patterns/monolithic.html。微服務架構也是一種架構風格。它的實現(xiàn)視圖由多個組件構成:一組可執(zhí)行文件或WAR文件。它的組件是服務,連接器是使這些服務能夠協(xié)作的通信協(xié)議。每個服務都有自己的邏輯視圖架構,通常也是六邊形架構。圖2-3顯示了FTGO應用程序可能的微服務架構。此架構中的服務對應

15、于業(yè)務功能,例如訂單管理和餐館管理。模式:微服務架構將應用程序構建為松耦合、可獨立部署的一組服務。請參閱:http:/microservices.io/patterns/microservices.html。圖3FTGO應用程序可能的微服務架構。它由眾多服務組成微服務架構強加的一個關鍵約束是服務松耦合。因此,服務之間的協(xié)作方式存在一定限制。為了解釋這些限制,我將嘗試定義什么是服務,解釋松耦合意味著什么,并告訴你為什么這很重要。什么是服務服務是一個單一的、可獨立部署的軟件組件,它實現(xiàn)了一些有用的功能。圖2-4顯示了服務的外部視圖,在此示例中是Order Service。服務具有API,為其客戶端

16、提供對功能的訪問。有兩種類型的操作:命令和查詢。API由命令、查詢和事件組成。命令如createOrder()執(zhí)行操作并更新數(shù)據(jù)。查詢,如findOrderById()檢索數(shù)據(jù)。服務還發(fā)布由其客戶端使用的事件,例如OrderCreated。服務的API封裝了其內部實現(xiàn)。與單體架構不同,開發(fā)人員無法繞過服務的API直接訪問服務內部的方法或數(shù)據(jù)。因此,微服務架構強制實現(xiàn)了應用程序的模塊化。微服務架構中的每項服務都有自己的架構,可能還有獨特的技術棧。但是典型的服務往往都具有六邊形架構。其API由與服務的業(yè)務邏輯交互的適配器實現(xiàn)。操作適配器調用業(yè)務邏輯,事件適配器對外發(fā)布業(yè)務邏輯產生的事件。圖4服務具

17、有封裝實現(xiàn)的API。API定義了由客戶端調用的操作。有兩種類型的操作:命令用來更新數(shù)據(jù),查詢用來檢索數(shù)據(jù)。當服務的數(shù)據(jù)發(fā)生更改時,服務會發(fā)布可供客戶端訂閱的事件在本書第12章討論部署技術時,你將看到服務的實現(xiàn)視圖可以采用多種形式。該組件可以是獨立進程,在容器中運行的Web應用程序或OSGI包、云主機或Serverless技術,等等。但是,一個基本要求是服務具有API并且可以獨立部署。什么是松耦合微服務架構的最核心特性是服務之間的松耦合性。服務之間的交互采用API完成,這樣做就封裝了服務的實現(xiàn)細節(jié)。這允許服務在不影響客戶端的情況下,對實現(xiàn)方式做出修改。松耦合服務是改善開發(fā)效率、提升可維護性和可測

18、試性的關鍵。小的、松耦合的服務更容易被理解、修改和測試。我們通過API來實現(xiàn)松耦合服務之間的協(xié)調調用,這樣就避免了外界對服務的數(shù)據(jù)庫的直接訪問和調用。服務自身的持久化數(shù)據(jù)就如同類的私有屬性一樣,是不對外的。保證數(shù)據(jù)的私有屬性是實現(xiàn)松耦合的前提之一。這樣做,就允許開發(fā)者修改服務的數(shù)據(jù)結構,而不用提前與其他服務的開發(fā)者互相協(xié)商。這樣做在運行時也實現(xiàn)了更好的隔離。例如,一個服務的數(shù)據(jù)庫加鎖不會影響另外的服務。但是你稍后就會看到在服務間不共享數(shù)據(jù)庫的弊端,特別是處理數(shù)據(jù)一致性和跨服務查詢都變得更為復雜。共享類庫的角色開發(fā)人員經常把一些通用的功能打包到庫或模塊中,以便多個應用程序可以重用它而無須復制代碼

19、。畢竟,如果沒有Maven或npm庫,我們今天的開發(fā)工作都會變得更困難。你可能也想在微服務架構中使用共享庫。從表面上看,它似乎是減少服務中代碼重復的好方法。但是你需要確保不會意外地在服務之間引入耦合。例如,想象一下多個服務需要更新Order業(yè)務對象的場景。一種選擇是將該功能打包為可供多個服務使用的庫。一方面,使用庫可以消除代碼重復。另一方面,如果業(yè)務需求的變更影響了Order業(yè)務對象,開發(fā)者需要同時重建和重新部署所有使用了共享庫的服務。更好的選擇是把這些可能會更改的通用功能(例如Order管理)作為服務來實現(xiàn),而不是共享庫。你應該努力使用共享庫來實現(xiàn)不太可能改變的功能。例如,在典型的應用程序中,在每個服務中都實現(xiàn)一個通用的Money類

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論