概述
本文從不同角度闡述什么是軟件架構(gòu),軟件架構(gòu)在做什么,在進(jìn)行軟件架構(gòu)設(shè)計(jì)時(shí)需要考慮哪些方面。
基本概念
軟件系統(tǒng)的架構(gòu)就是有它的構(gòu)建者所決定的,軟件架構(gòu)這項(xiàng)工作的實(shí)質(zhì)就是:如何將系統(tǒng)切分成組件,并安排好組件之間的排列關(guān)系,以及組件之間的相互通信的方式。
而設(shè)計(jì)軟件架構(gòu)的目的就是:為了在工作中更好的對(duì)這些組件進(jìn)行研發(fā)、部署、運(yùn)行及其維護(hù)。
設(shè)計(jì)良好的架構(gòu):可以讓系統(tǒng)更容易理解、易于修改、方便維護(hù)、并能輕松部署。
軟件架構(gòu)的終極目標(biāo):最大化程序員的生產(chǎn)力,同時(shí)最小化系統(tǒng)的總運(yùn)維成本。
開發(fā)
一個(gè)開發(fā)起來很困難的軟件系統(tǒng),不太可能有一個(gè)長(zhǎng)久的長(zhǎng)久、健康的生命周期。
系統(tǒng)架構(gòu)設(shè)計(jì)的作用,就是方便其團(tuán)隊(duì)對(duì)它進(jìn)行開發(fā)。
運(yùn)行
設(shè)計(jì)良好的系統(tǒng)架構(gòu)應(yīng)該可以使開發(fā)人員對(duì)系統(tǒng)的運(yùn)行一目了然。
架構(gòu)應(yīng)該起到揭示系統(tǒng)運(yùn)行過程的作用。
系統(tǒng)架構(gòu)應(yīng)該將系統(tǒng)中的用例,功能,以及必備行為,設(shè)置為對(duì)開發(fā)者可見的一級(jí)實(shí)體,簡(jiǎn)化他們對(duì)系統(tǒng)的理解。這將會(huì)對(duì)系統(tǒng)的開發(fā)與維護(hù),提供極大的幫助。
部署
在設(shè)計(jì)的早期就要考慮到部署問題,
為了讓開發(fā)成為有效的工作,軟件系統(tǒng)就必須是可部署的。
通常一個(gè)系統(tǒng)的部署成本越高,可用性就越低。所以,實(shí)現(xiàn)一鍵輕松部署應(yīng)該是設(shè)計(jì)軟件架構(gòu)的一個(gè)目標(biāo)。
維護(hù)
在軟件系統(tǒng)所有方面中,維護(hù)所需要的成本是最高的。需求的變更,新功能的添加,以及系統(tǒng)缺陷這些工作將會(huì)占去大部分人力資源。
系統(tǒng)維護(hù)的主要成本,包括兩個(gè)方面:
新增功能:確定新增功能或修復(fù)問題的最佳位置。
風(fēng)險(xiǎn)成本:在進(jìn)行系統(tǒng)代碼修改時(shí),可能衍生出新的問題。
通過優(yōu)良的架構(gòu)設(shè)計(jì),可以減少維護(hù)成本:
將系統(tǒng)切分成各個(gè)組件(模塊)。
使用穩(wěn)定的接口把各個(gè)組件之間進(jìn)行隔離。這樣讓各個(gè)組件之間保持正交性,各個(gè)組件之間解耦。
將未來需要添加新功能的添加方式明確出來,可以大大降低對(duì)系統(tǒng)其他部分造成的傷害的可能性。
如何提前考慮新功能的添加方式?
比如支持?jǐn)?shù)據(jù)庫(kù):可以編寫數(shù)據(jù)服務(wù)層,并設(shè)計(jì)成接口;當(dāng)需要支持新的數(shù)據(jù)庫(kù)時(shí),只需要按新的數(shù)據(jù)庫(kù)的驅(qū)動(dòng)實(shí)現(xiàn)接口,其他模塊或業(yè)務(wù)上層代碼保持不變。
保持可選項(xiàng):
讓軟件盡可能長(zhǎng)時(shí)間地保留盡可能多的可選項(xiàng)。
所有的軟件系統(tǒng),可以分解為:策略和細(xì)節(jié);策略:軟件中的業(yè)務(wù)核心,它是系統(tǒng)真正價(jià)值所在;細(xì)節(jié):是指操作該系統(tǒng)的人,其他系統(tǒng)與策略進(jìn)行交互,但又不影響策略本身的行為。
軟件架構(gòu)師的目標(biāo):創(chuàng)建一種系統(tǒng)形態(tài),以策略為基本元素,并讓細(xì)節(jié)與策略脫離關(guān)系,允許在具體決策過程中,推遲或延遲與細(xì)節(jié)相關(guān)的內(nèi)容。
比如:在開發(fā)早期,開發(fā)高層策略時(shí),應(yīng)該無須選擇數(shù)據(jù)庫(kù)系統(tǒng),不用確定使用的web服務(wù),不用確定是否使用REST接口。就是說:軟件的高層,與這些東西沒有關(guān)系。
設(shè)備無關(guān):
不同硬件上都能直接部署,而且得到的結(jié)果是相同的。
這個(gè)原則,對(duì)軟件開發(fā)和部署非常重要。
參考書籍
該文章在 2023/3/6 16:34:17 編輯過