首頁技術(shù)文章正文

Java中可以使用哪些系統(tǒng)架構(gòu)?怎樣選擇?

更新時間:2023-07-06 來源:黑馬程序員 瀏覽量:

架構(gòu),又名軟件架構(gòu),是有關(guān)軟件整體結(jié)構(gòu)與組件的抽象描述,用于指導大型軟件系統(tǒng)各個方面的設計。

Java企業(yè)級的應用根據(jù)業(yè)務的復雜程度,通常使用的系統(tǒng)架構(gòu)有應用架構(gòu)、垂直應用架構(gòu)、面向服務的架構(gòu)(Service-Oriented Architecture,SOA)、微服務架構(gòu)等。

項目架構(gòu)的選擇在項目準備過程中占據(jù)著重要的位置,除此之外技術(shù)架構(gòu)的選擇也是項目準備過程中必不可少的一個環(huán)節(jié),接下來將針對項目架構(gòu)和技術(shù)架構(gòu)的選擇進行詳細講解。

單體應用架構(gòu)

單體應用架構(gòu)是把所有業(yè)務場景的表示層、業(yè)務邏輯層和數(shù)據(jù)訪問層放在一個工程中,經(jīng)過編譯打包,部署在一臺服務器上。

1688624746400_單體架構(gòu).png

單體應用架構(gòu)開發(fā)的進銷存系統(tǒng)

優(yōu)點:項目架構(gòu)簡單,技術(shù)結(jié)構(gòu)單六,前期用人成本低,適合小型系統(tǒng)的開發(fā)。

缺點:隨著業(yè)務復雜度的增加,功能越來越多,代碼量越來越大,會導致代碼可讀性、可維護性和可擴展性下降。由于系統(tǒng)過大且關(guān)聯(lián)較多,任何一個ug都有可能導致整個系統(tǒng)宕機。

垂直應用架構(gòu)

垂直應用架構(gòu)將單體應用拆分成若干個獨立的小應用,每個小應用獨立的部署到不同的服務器上,以提升效率。

 

1688624887248_進銷存系統(tǒng).png

垂直應用架構(gòu)開發(fā)的進銷存系統(tǒng)

優(yōu)點:通過垂直拆分實現(xiàn)流量分擔,減輕服務器壓力;可以針對不同的應用進行優(yōu)化,方便水平擴展,容錯率提高。

缺點:當垂直應用越多,應用之間可能發(fā)生相互調(diào)用,不同應用之間可能出現(xiàn)數(shù)據(jù)、代碼、功能冗余。

SOA

SOA是面向服務的架構(gòu),它將應用程序的不同功能單元(簡稱服務)進行拆分,并通過這些服務之間定義的接口和協(xié)議將其聯(lián)系起來。

 

1688625413535_soa.png

SOA開發(fā)的進銷存系統(tǒng)

優(yōu)點:將公共的功能抽取為服務,提高開發(fā)效率;各個服務之間耦合度低,可讀性和可維護性比較好。

缺點:抽取服務的粒度較大,服務提供方與調(diào)用方接口耦合度較高。

微服務架構(gòu)

微服務架構(gòu)是SOA架構(gòu)的升級,每一個服務就是一個獨立的部署單元,服務之間的耦合性很低。

 

1688625616479_微服務.png

微服務架構(gòu)開發(fā)的進銷存系統(tǒng)

優(yōu)點:開發(fā)模式更加靈活;微服務的.獨立打包、部署和升級,使小團隊的交付周期將縮短,運維成本下降。

缺點:對技術(shù)要求較高;微服務過多會造成服務管理成本提高,不利于系統(tǒng)維護,服務拆分粒度過細也會導致、系統(tǒng)變得凌亂和笨重。

在開發(fā)時通常會根據(jù)不同的需求將項目拆分為多個層次處理,開發(fā)者可以根據(jù)不同的需求由其相對應的技術(shù)棧提供解決方案。


分享到:
在線咨詢 我要報名
和我們在線交談!