软件体系架构模式之二分层体系结构
分層體系結(jié)構(gòu)模式是n層模式,其中組件被組織在水平層中。這是設(shè)計大多數(shù)軟件的傳統(tǒng)方法,并且具有獨立性。這意味著所有組件都是互連的,但彼此之間不依賴。
圖1:分層架構(gòu)
在此體系結(jié)構(gòu)中有四層,其中每一層在模塊和其中的組件之間都有聯(lián)系。從上到下分別是:
表示層:它包含與表示層相關(guān)的所有類別。
業(yè)務(wù)層:包含業(yè)務(wù)邏輯。
持久層:用于處理對象關(guān)系映射之類的功能
數(shù)據(jù)庫層:這是所有數(shù)據(jù)的存儲位置。
在這種情況下,層是關(guān)閉的,這意味著請求必須從上到下遍歷所有層。這樣做有兩個原因,一個是所有“相似”組件都在一起,另一個是它提供了隔離層。
詳細地說,將“相似”的組件放在一起意味著與某個層相關(guān)的所有內(nèi)容都停留在該單個層中。這樣一來,就可以在組件的類型之間進行清晰的分隔,并且還可以將類似的編程代碼集中在一個位置。通過隔離各層,它們變得彼此獨立。因此,例如,如果我們要將數(shù)據(jù)庫從Oracle服務(wù)器更改為SQL服務(wù)器,這將對數(shù)據(jù)庫層產(chǎn)生很大的影響,但不會影響其他任何層。同樣,假設(shè)您有一個自定義的書面業(yè)務(wù)層,并想為業(yè)務(wù)規(guī)則引擎進行更改。如果我們擁有定義良好的分層體系結(jié)構(gòu),則更改不會影響其他層。
圖2:分層架構(gòu)中的數(shù)據(jù)傳播
可以對分層體系結(jié)構(gòu)模式進行修改,以在提到的層之外增加其他層。這稱為混合分層體系結(jié)構(gòu)。例如,在業(yè)務(wù)層和持久層之間可以有一個服務(wù)層。但是,這不是理想的方案,因為現(xiàn)在業(yè)務(wù)層必須經(jīng)過服務(wù)層才能到達持久層。通過服務(wù)層,此請求不會獲得任何價值。我們將其稱為架構(gòu)漏洞反模式。請求通過層,而在每個層中執(zhí)行的邏輯很少或沒有邏輯。
圖3:分層架構(gòu)模式中的開放層
解決此問題的唯一方法是將可選層設(shè)置為開放層。這意味著,如果可選層將任何值添加到正在發(fā)送的請求中,那么請求將通過它。如果不是,那么它將簡單地繞過該層,然后轉(zhuǎn)到相關(guān)層。從上圖中可以看出,請求繞過了服務(wù)層,并從業(yè)務(wù)層移到了持久層。
但是請注意,通過使用開放層,可以消除使用隔離層的好處。如果要交換持久層,則必須考慮開放服務(wù)層以及業(yè)務(wù)層。這兩個層現(xiàn)在都耦合到持久層。因此,盡管很容易向系統(tǒng)中添加開放層,但不應(yīng)允許它發(fā)生。我們必須設(shè)法解決問題而不損害體系結(jié)構(gòu)。
結(jié)論
分層架構(gòu)是軟件架構(gòu)模式的最簡單形式。如果您要設(shè)計一個基本的應(yīng)用程序,其中用戶數(shù)量很少(<100–200),并且您確定上線后不會有太多的需求變更,那么這是最好的軟件架構(gòu)模式。與其他模式相比,此體系結(jié)構(gòu)模式的實現(xiàn)成本非常低。
以下是分層架構(gòu)模式的利弊分析。
優(yōu)點
由于組件屬于特定層,因此易于測試。因此,它們可以單獨進行測試。
它很容易實現(xiàn),因為自然而然,大多數(shù)應(yīng)用程序都是分層工作的。
缺點
盡管可以對特定的層進行更改,但這并不容易,因為應(yīng)用程序是單個單元。而且,層之間的耦合趨于使其變硬。這也使得難以擴展。
必須將其部署為單個單元,因此更改為特定層意味著必須重新部署整個系統(tǒng)。
它越大,請求通過多個層所需的資源就越多,因此將導(dǎo)致性能問題。
原文:https://medium.com/@priyalwalpita
總結(jié)
以上是生活随笔為你收集整理的软件体系架构模式之二分层体系结构的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 护栏多少钱一米啊?
- 下一篇: 软件体系架构模式之三微内核体系架构