2021-03-02 分類: 網(wǎng)站建設(shè)
阿里妹導(dǎo)讀:架構(gòu)圖是什么?為什么要畫架構(gòu)圖?如何畫?有哪些方法?本文從架構(gòu)的定義說起,分享阿里文娛高級技術(shù)專家簫逸關(guān)于畫架構(gòu)圖多年的經(jīng)驗總結(jié),并對抽象這一概念進(jìn)行了深入地討論。較長,同學(xué)們可收藏后再看。
文末福利:架構(gòu)師成長秘籍。
什么是架構(gòu)圖?
如何畫好一張架構(gòu)圖,要做好這件事情首先要回答的就是什么是架構(gòu)圖。我們?nèi)粘9ぷ髦薪?jīng)常能看到各種各樣的架構(gòu)圖,而且經(jīng)常會發(fā)現(xiàn)大家對架構(gòu)圖的理解各有側(cè)重。深入追究到這個問題,可能一下子還很難有一個具象的定義,如果我們把這個問題進(jìn)行拆分(如下圖)理解起來就會容易一點。
架構(gòu)圖 = 架構(gòu) + 圖
按照這個等式,我們可以把問題轉(zhuǎn)換:
圖是什么?這個比較容易回答,圖是一種信息的表達(dá)方式,所以架構(gòu)圖,即表達(dá)“架構(gòu)”的圖,也就是一種架構(gòu)的表達(dá)方式。也即:
架構(gòu)圖 = 架構(gòu)的表達(dá) = 表達(dá)架構(gòu)的圖
按照這種思路我們需要回答:
接下來的內(nèi)容基本上就是按照這兩個維度來做分析。
什么是架構(gòu)?要表達(dá)的到底是什么?
Linus 03 年在聊到拆分和集成時有一個很好的描述:
I claim that you want to start communicating between independent modules no sooner than you absolutely HAVE to, and that you should avoid splitting things up until you really need to, because that communication complexity often swamps the complexity of the actual pieces involved in it.(讓我們認(rèn)識到一種現(xiàn)象,把復(fù)雜系統(tǒng)拆分成模塊,似乎并沒有降低整個系統(tǒng)的復(fù)雜度。它降低的只是子系統(tǒng)的復(fù)雜度。而整個系統(tǒng)的復(fù)雜度,反而會由于拆分后的模塊之間,不得不進(jìn)行交互,變得更加復(fù)雜。)
我理解這里描述的系統(tǒng)拆分就是架構(gòu)的過程,基本出發(fā)點是為了效率,通過架構(gòu)的合理拆分(無論是空間還是時間上的拆分),最終目的讓效率大化。那到底什么是架構(gòu),其實沒有完全統(tǒng)一且明確的定義,如下三個定義可以參考。
在百度百科上的定義:
架構(gòu),又名軟件架構(gòu),是有關(guān)軟件整體結(jié)構(gòu)與組件的抽象描述,?于指導(dǎo)?型軟件系統(tǒng)各個方面的設(shè)計。
在 Wikipedia 上的定義:
Architecture is both the process and the product of planning, designing, and constructing buildings or any other structures.
ISO/IEC 42010:20072 中對架構(gòu)有如下定義:
The fundamental organization of a system, embodied in its components, their relationships to each other and the environment, and the principles governing its design and evolution.
這三個定義也是見仁見智,但是我們基本可以得出:架構(gòu)體現(xiàn)的是整體結(jié)構(gòu)和組件之間的關(guān)系。
架構(gòu)的本質(zhì)
這里引用三個觀點來探討架構(gòu)的本質(zhì):
上述三個觀點提到的內(nèi)容,基本表達(dá)了架構(gòu)的核心目的:管理復(fù)雜性,效率大化。以及架構(gòu)的兩個主要變化來源:一個是以改善軟件質(zhì)量為目的的內(nèi)在結(jié)構(gòu)性變化;另外一個是以滿足客戶需求為目的的外在功能性變化。無論是何種變化,在我看來架構(gòu)都是在不斷的判斷和取舍,在業(yè)務(wù)需求和系統(tǒng)實現(xiàn)之間做權(quán)衡,從而來應(yīng)對未來變化的不確定性,如下圖可以比較粗淺直觀的表達(dá)這種理解。
要表達(dá)的是什么?
在 EA 架構(gòu)領(lǐng)域,有兩種常見架構(gòu)方法 RUP 和 TOGAF,這兩個框架也是我們常常了解架構(gòu)分類的兩個維度。從個人的角度,我自己覺得 TOGAF 的分類方式更加廣泛使用(如下右圖)。
結(jié)合日常的業(yè)務(wù)開發(fā),其實我們更多的是關(guān)注業(yè)務(wù)架構(gòu)和應(yīng)用架構(gòu),所以把上邊的表達(dá)式進(jìn)一步的拆解,在回答如何畫好一張架構(gòu)圖之前,我們需要關(guān)注業(yè)務(wù)架構(gòu)和系統(tǒng)架構(gòu),討論清楚如何進(jìn)行業(yè)務(wù)架構(gòu)和系統(tǒng)架構(gòu)。
架構(gòu)的過程其實就是建模的過程
我們都知道現(xiàn)實世界到軟件世界或者面向?qū)ο蟮氖澜绲倪^程,是一個不斷抽象的過程,這其中的方法就是不斷的建立模型。從現(xiàn)實世界到業(yè)務(wù)模型,從業(yè)務(wù)模型到概念模型,從概念模型到設(shè)計模型,通過不斷的抽象去粗取精,形成對現(xiàn)實世界的層層抽象,所以架構(gòu)的過程其實就是建模的過程。至此,我們有必要了解一下什么是建模。
百度百科定義:
建模就是建立模型,就是為了理解事物而對事物做出的一種抽象,是對事物的一種無歧義的書面描述。
《Thinking in UML》定義:
建模(Modeling),是指通過對客觀事物建立一種抽象的方法用以表征事物并獲得對事物本身的理解,同時把這種理解概念化,將這些邏輯概念組織起來,構(gòu)成一種對所觀察的對象的內(nèi)部結(jié)構(gòu)和工作原理的便于理解的表達(dá)。
從上述兩個定義上基本可以了解到建模就是抽象,對業(yè)務(wù)或現(xiàn)實世界的抽象,雖然不足以幫我們理解架構(gòu)本身,但是可以將我們上述關(guān)注的業(yè)務(wù)架構(gòu)和系統(tǒng)架構(gòu)進(jìn)一步向下 Down 一層,架構(gòu)的過程是建模的過程,我們轉(zhuǎn)換成兩個簡單的問題:模是什么?如何建?
模是什么?如何建?
這是兩個比較容易陷入理論性的問題,我們跳出來從結(jié)果看過程。接下來通過已經(jīng)產(chǎn)出的一些架構(gòu)圖來反向看這些架構(gòu)圖是如何產(chǎn)出的,同時來回答這兩個問題。
業(yè)務(wù)建模
回到當(dāng)下業(yè)務(wù)本身,對我而言也是全新的,在最初接觸的時候憑僅有的行業(yè)背景去理解,結(jié)合了大量的文檔閱讀最終產(chǎn)出了如下圖示的《業(yè)務(wù)核心流程圖》和《業(yè)務(wù)功能模塊圖》。這兩張圖基本上就涵蓋了所有的業(yè)務(wù)內(nèi)容。左邊的業(yè)務(wù)流程圖得到了這個行業(yè) 20 多年從業(yè)經(jīng)驗專家認(rèn)可,他認(rèn)為這就是 20 多年所從事的業(yè)務(wù)內(nèi)容。
圖片源于網(wǎng)絡(luò),為示意圖,侵刪
回溯整個過程,特別是左側(cè)的業(yè)務(wù)核心流程圖,今天創(chuàng)新互聯(lián)看這張流程圖很容易構(gòu)架起一個基本邏輯來,縱向是不同的業(yè)務(wù)角色和系統(tǒng),橫向是時間的推進(jìn),特別容易理解。但我想說最開始的理解和分析是極其耗時和壓力極大的過程。這個過程中我所用的方法就是:
1)把書讀厚
下圖基本涵蓋“把書讀厚”的過程,匯聚大量的文檔信息,嘗試用多維度去形成邏輯。這個維度可能是依據(jù)歷史經(jīng)驗,也可能是依據(jù)文檔內(nèi)容,比如在形成業(yè)務(wù)大圖的過程中,我曾按可能的場景邏輯、可能的系統(tǒng)或領(lǐng)域邏輯分別把多個文檔中的內(nèi)容歸類,探求可能性。
這個過程會很枯燥,特別是涉及一些業(yè)務(wù)的術(shù)語內(nèi)容,理解起來就會很困難。我的方式就是把自己當(dāng)做一名“探索者”,如同我們玩游戲一樣,常常問自己“我的游戲地圖全部點亮了嗎?”未必要照顧到所有細(xì)節(jié),但是需要力求覆蓋整體內(nèi)容。仔細(xì)想想,似乎也和日常的讀書類似,這期間值得注意的是:
2)把書讀薄
這個時候的重點是建立“大局觀”,嘗試梳理自己的邏輯主線,常規(guī)邏輯上講都會劃分為橫縱,或者矩陣式的框架,當(dāng)然這需要建立在前期的理解和分析上,這里常常隱含一個最最重要的假設(shè):系統(tǒng)一定是給人用的,一定是解決客戶問題的,否則毫無存在的意義。所以核心的套路是:誰?用什么樣的服務(wù)/功能/能力?解決什么樣的問題?從而刻畫出:參與者角色、系統(tǒng)能力、交互關(guān)系,需要常常問自己的是:邊界是什么?輸入輸出是什么?逐步的通過用例來梳理出業(yè)務(wù)功能,形成角色—>主流程—>分支流程,進(jìn)而通過不斷的歸納演繹形成最終的業(yè)務(wù)抽象描述“一張圖”。
一個小的細(xì)節(jié)是不能妄圖通過這些過程迅速在大腦里完成大圖的繪制,還是需要從小的環(huán)節(jié)做起,把一部分小的業(yè)務(wù)閉環(huán)做成一個個的小組塊,不要讓它再占用大腦的空間,然后逐步的整體思考和把握,漸進(jìn)式的形成大圖;與此同時,大圖的樣式美觀先完全忽略,走通邏輯再細(xì)致調(diào)整。之所以強(qiáng)調(diào)這個細(xì)節(jié),是因為嘗試通過“一張圖”去描述一個非常大的業(yè)務(wù)本身就是件很有挑戰(zhàn)的事情,如果不這么做容易讓自己變得焦慮和急躁,這是一個慢功夫,需要耐心,需要在關(guān)鍵阻塞的地方慢下來,甚至一遍一遍的反復(fù)才能最終完成。
3)邏輯對照
這是一個閉環(huán)封裝的過程,把前期“讀厚”過程中的記錄,一些邏輯細(xì)節(jié)、關(guān)鍵流程都要逐一放到大圖里去對照驗證,確保業(yè)務(wù)理解的完整性和準(zhǔn)確性,確保業(yè)務(wù)抽象能夠覆蓋所有已知的業(yè)務(wù)用例,甚至能夠支持可能的業(yè)務(wù)場景。這個環(huán)節(jié)也是必不可少的部分。
總結(jié)一下業(yè)務(wù)建模(如下圖),通過上述三個主要的過程,我們基本可以產(chǎn)出一些業(yè)務(wù)架構(gòu)的大圖、框圖、流程圖、用例圖等等,是什么樣的圖并不重要,重要的是這個圖面對的是誰?主要用來做什么?我后邊也會講到畫圖角度的問題。從我們目前的業(yè)務(wù)場景上看,業(yè)務(wù)架構(gòu)圖的核心目的是統(tǒng)一共識、減少溝通成本,無論是項目中的哪個角色大家都能講一樣的話,描述一樣的事情。這就是建立對話能力和對話語境,特別是有大量外部客戶的時候,一方面體現(xiàn)我們自己專業(yè)性很重要,另外一方面這種與客戶對話的能力更重要,這也是上文中提到為什么要盡可能用原汁原味的文字去呈現(xiàn)一張圖的目的。
系統(tǒng)建模
通過業(yè)務(wù)建模完成了從現(xiàn)實世界到業(yè)務(wù)模型的構(gòu)建,在此基礎(chǔ)上,如何通過抽象完成業(yè)務(wù)模型到設(shè)計模型的映射,這是系統(tǒng)建模要解決的問題。從研發(fā)實現(xiàn)的角度,這個階段會產(chǎn)出各種各樣的模型圖,比如實體模型圖、時序圖、狀態(tài)圖、各個層次的架構(gòu)圖等等,但是無論何種角度,何種層次,系統(tǒng)建模一定是在業(yè)務(wù)建模的基礎(chǔ)上,完成業(yè)務(wù)需求到系統(tǒng)模型之間的映射;這其中涉及業(yè)務(wù)功能到系統(tǒng)能力、業(yè)務(wù)流程到數(shù)據(jù)流程的映射;系統(tǒng)建模更強(qiáng)調(diào)職責(zé)、依賴、約束關(guān)系,用于指導(dǎo)研發(fā)的落地實現(xiàn)。
拋開具體的時序圖、狀態(tài)圖不談,簡單看一下如下幾個維度的架構(gòu)圖:
圖片源于網(wǎng)絡(luò),為示意圖,侵刪
上述幾張圖的視角、層次和面向用戶各不相同,基本上都能看到整體,但是細(xì)節(jié)程度不同,側(cè)重表達(dá)的信息也完全不同。那么系統(tǒng)建模時應(yīng)該如何去做呢,這個過程中我常常用的方法是(不盡然如此):
1)“剝洋蔥”
在業(yè)務(wù)建模結(jié)果的基礎(chǔ)上進(jìn)行“剝洋蔥”。這是一個不斷拆解的過程,這個過程中的拆解非常重要的方式是就系統(tǒng)分工。如何分工?哪個模塊負(fù)責(zé)什么?模塊的輸入和輸出是什么?內(nèi)部提供什么樣的服務(wù)和能力?這幾個問題在后文關(guān)于抽象的部分回答。一句話總結(jié)“剝洋蔥”就是:從業(yè)務(wù)建模的“大局觀”去按職責(zé)分工拆解成多個子系統(tǒng)、多個子模塊、然后在模塊能進(jìn)行細(xì)分,層層剝解。
2)核心實體抽取
關(guān)于核心實體的抽取,這里的關(guān)鍵問題是:哪些是實體?如何判斷核心實體?如何抽取?抽取后的結(jié)果是什么樣的?很難用一種方法論的形式去描述,我也沒有完全形成我自己一成不變的方法論,但是我覺得如下三種方式可以供大家參考。
實體(Entity):客觀存在并可相互區(qū)別的事物稱之為實體。實體可以是具體的人、事、物,也可以是抽象的概念或聯(lián)系。
從這個概念理解,和我們面向?qū)ο笕f物兼對象的理解是基本一致的。所以實體的抽取也可以借鑒對象分析的方法:獨立、可抽象、有層次性、在單個層次上又具備原子性。如下圖是《Thinking in UML》中關(guān)于對象的分析方法。
通過從業(yè)務(wù)用例中,去提取其中的關(guān)鍵詞,不同的關(guān)鍵詞可能表達(dá)了實體、關(guān)系、屬性等等內(nèi)容,從而完成模型分析與建立。這里引用六銖老師在《問題空間領(lǐng)域模型基本抽象方法》中的的內(nèi)容,簡述如下:
一句完整的用例描述中,首先找名詞,以「主語」和「賓語」為主,這些名詞基本可以確定我們的實體;其次找形容詞,存在于「定語」和「狀語」中,找到形容詞基本可以確定對應(yīng)屬性的值;然后通過對用例的補充,細(xì)化,對名詞進(jìn)行定義,慢慢的,我們會得到我們的領(lǐng)域模型和對應(yīng)的屬性。最后通過動詞&形容詞(存在于【謂語】,【狀語】,【定語】)來確定他們之間的關(guān)聯(lián)關(guān)系。
這是《聊聊架構(gòu)》中提的方式,具體講就是通過尋找問題的主體,然后分析主體的生命周期,進(jìn)而通過區(qū)分生命周期里的關(guān)鍵活動來聚焦主體的關(guān)鍵屬性和關(guān)鍵關(guān)系。推薦大家閱讀前 9 章的內(nèi)容,總計才 40 頁的內(nèi)容,可能會有所體會。這里舉一個書中的例子:
一個笑話:一位女士對老公說:把袋子里的土豆削一半下鍋;結(jié)果所有土豆都下鍋了,而且每個土豆被削了一半。
作者指出,這里其實就沒有清晰的設(shè)別主體,這個主體不單是土豆,而是隱含的人要吃土豆,包括人和土豆兩個實體,這兩個實體之間的關(guān)系就是要解決的業(yè)務(wù)場景:怎樣吃?如何吃?為什么吃?所以主體識別不清楚,可能會導(dǎo)致整體實現(xiàn)的偏離。當(dāng)然實際過程中不會犯這么愚蠢的錯誤,但是也側(cè)面說明核心實體的抽取是非常關(guān)鍵的。
3)終極武器:自己講給自己
實際的業(yè)務(wù)開發(fā)中,往往一種業(yè)務(wù)設(shè)計實現(xiàn)要滿足上層N個業(yè)務(wù)場景,這其中有共性也有個性化訴求,這個過程中我們很容易被多場景之間的異同搞混亂,要么邏輯不清晰、要么過度設(shè)計、要么考慮不周。我觀察過很多同學(xué)包括我自己,在一定的業(yè)務(wù)復(fù)雜度時容易失去設(shè)計的焦點。我的做法與業(yè)務(wù)建模類似,一定要邏輯對照:在所有的設(shè)計/邏輯模糊的點,將所有已知場景分別套入,自己講給自己。請注意這里是“分別套入”,在當(dāng)前的設(shè)計層次下一個場景驗證完再去驗證下一個場景,找出阻塞的、模糊的點,重新梳理再優(yōu)化設(shè)計。系統(tǒng)建模的結(jié)果指導(dǎo)我們軟件設(shè)計實現(xiàn),所以一定要反復(fù)梳理打通,這個反復(fù)的過程其實也是提升架構(gòu)能力的過程,累積到一定程度就會自然通透。
回到開始的那個問題:
模是什么?通過上面業(yè)務(wù)建模和系統(tǒng)建模的描述,簡單來講模就是業(yè)務(wù)的映射,這個映射的結(jié)果是業(yè)務(wù)模型、概念模型或設(shè)計模型,但是所有的出發(fā)點都是業(yè)務(wù)需求:客戶是誰?核心訴求是什么?
如何建?上面通過業(yè)務(wù)建模和系統(tǒng)建模兩個維度,從個人實踐角度大概講了常規(guī)的套路,建模的本質(zhì)其實一個抽象的過程,但是上述業(yè)務(wù)和系統(tǒng)建模抽象的過程其實還有兩個問題并沒有完全說清楚:
說回抽象
Haskell 語言的設(shè)計者之一 Paul Hudak 曾說過一句略帶夸張的話:編程中最重要的三件事是:抽象,抽象,抽象。
“abstraction, abstraction, abstraction”are the three most important things in programming。
如果要問程序員最重要的能力有哪些,我相信抽象一定是其中最重要的之一。那到底什么是抽象?
百度百科定義:
從具體事物抽出、概括出它們共同的方面、本質(zhì)屬性與關(guān)系等,而將個別的、非本質(zhì)的方面、屬性與關(guān)系舍棄,這種思維過程,稱為抽象。
如果更精煉的概括:抽象就是做減法和做除法。通過舍棄非本質(zhì)和無關(guān)緊要的部分,著眼于問題的本質(zhì),去粗取精;通過透過現(xiàn)象看本質(zhì),發(fā)現(xiàn)不同事物之間的共同之處,異中求同,同類歸并,也就是做除法。上文中建模過程是共性抽象,通過不斷的抽象達(dá)到某個狀態(tài)為止,我理解這個狀態(tài)沒有確定性的答案,核心就是滿足業(yè)務(wù)場景的需要,其實這背后也有一個邊界的問題。
抽象的角度
生活中處處都是抽象,但是我們似乎少了為什么是這樣或那樣抽象的思考。抽象是有角度之分的。
生活中我們常常說“我的觀點是…”,其實這里的“觀點”就是一個角度問題,從一定的立場或角度出發(fā),對事物或問題所持的看法。以生活中的常見的實物來說(如下圖),我們是否能快速的說出其中的相同點和不同點。
如圖中已經(jīng)標(biāo)注的,我們從功用的角度對它們定義了椅子、桌子、凳子和柜子這樣的區(qū)分,但顯然很有很多很多角度,比如:物料、文字、高矮等等維度,從不同維度看過去,會有完全不同的相同點和不同點表述,所以,本質(zhì)是什么?本質(zhì)是:
重新回到我們前邊的兩個問題,業(yè)務(wù)建模中我們談到了歸類,按什么去歸類,答案呼之欲出,按我們的業(yè)務(wù)流程去歸類、按客戶的角色去歸類,又回到了那個最初始的問題:客戶是誰?核心訴求是什么?
同時,上文中我們提到,模是業(yè)務(wù)的映射,基于對抽象的理解,我們可以進(jìn)一步展開:模是在確定抽象角度下的業(yè)務(wù)映射。
抽象的層次
Wikipedia 關(guān)于抽象的定義中有一個關(guān)于報紙的例子:
1. 我的 5 月 18 日的《舊金山紀(jì)事報》
2. 5 月 18 日的《舊金山紀(jì)事報》
3. 《舊金山紀(jì)事報》
4. 一份報紙
5. 一個出版品
這五句話中,我們可以感受到抽象的層次,抽象層次越高,細(xì)節(jié)越少,普適性越強(qiáng)。再比如下圖中關(guān)于網(wǎng)絡(luò)模型的抽象,關(guān)于操作系統(tǒng)內(nèi)核的抽象,我們可以明顯的看到不同層次的抽象,就是過濾不同的信息,最終留下來的信息才是當(dāng)前抽象層次所需要的信息。從系統(tǒng)設(shè)計實現(xiàn)上來說,抽象層次越高,越接近設(shè)計,越遠(yuǎn)離實現(xiàn),同時抽象的模型越不受細(xì)節(jié)的羈絆,穩(wěn)定性越高,普適性越強(qiáng),可重用性就越高。
那么這里抽象的劃分層次的依據(jù)是什么?原則又是什么?我的經(jīng)驗是,劃分抽象層次的依據(jù)主要包含兩個:
其實這個也不能完全解釋如何分層,原則是什么?我覺得這是幾個最通用的原則:
考慮抽象層次的好處是不論在哪一個層次上,我們只需要面對有限的復(fù)雜度,從而專心考慮這個層次上的抽象是什么,要表達(dá)的信息是什么。
抽象的邊界
除了角度、層次之外,我們還需要考慮的抽象的邊界。如果說層次考慮的是縱向維度的表達(dá),那么邊界考慮的是橫向維度的表達(dá)。如何確定邊界,一個總的原則是按照職責(zé)進(jìn)行劃分,這里的職責(zé)其實也就是分工。一旦職責(zé)確定,我們在做建模分析時就不需要把整個業(yè)務(wù)大局放進(jìn)來從頭到尾去分析一遍,我們只需要考慮當(dāng)前分工下的上游和下游即可,這樣的信息量大大減少,自然的我們面對的領(lǐng)域復(fù)雜度也會降低到一定程度。
如果一定要給出邊界的定義,我的理解是:邊界是在確定抽象角度下,通過尋找核心的業(yè)務(wù)活動,抽取核心實體,進(jìn)一步確定實體核心生命周期的結(jié)果。可能有一點點繞,關(guān)鍵詞是:核心業(yè)務(wù)活動、核心實體、核心實體生命周期。
以現(xiàn)場娛樂行業(yè)為例,如下這張圖包含了高抽象層次下業(yè)務(wù)的全生命周期,這個抽象層次下的主體是什么,我的理解是票,項目生產(chǎn)的結(jié)果是票,分銷或電商服務(wù)是對票的銷售,現(xiàn)場是對票的核驗,至此以票為核心實體的生命周期結(jié)束。
如果我們往下 Down 一層,從項目生產(chǎn)這一個業(yè)務(wù)活動去看,整個業(yè)務(wù)流程是這樣:
項目管理->場館座位分銷->票房預(yù)測->場次管理->配額管理->繪座->票房規(guī)劃
從生產(chǎn)這個視角去看,核心的實體不是票,而是場次(確定時間、確定地點、確定內(nèi)容的一場演出或賽事),所有的關(guān)鍵業(yè)務(wù)活動都是以場次為維度,生產(chǎn)領(lǐng)域里需要考慮的主要就是場次的核心生命周期。
所以,在不同的抽象角度、不同的抽象層次,根據(jù)分工的不同會有不同的核心業(yè)務(wù)活動、不同的核心實體、邊界的確定關(guān)鍵在尋找核心的生命周期。尋找生命周期的過程,就是發(fā)現(xiàn)內(nèi)聚的過程;將所有關(guān)于生命周期的業(yè)務(wù)活動累積,就可以提升領(lǐng)域或模塊的內(nèi)聚性。
抽象的評估
前邊我們基本說清楚了抽象的角度、層次和邊界,從三個維度確定了抽象的結(jié)果。那么如何評估抽象結(jié)果的好壞呢?答案是“高內(nèi)聚,低耦合”,當(dāng)然還有更多的原則,但是單從實踐的角度,我覺得這是最最重要的。
耦合是軟件結(jié)構(gòu)中各模塊之間相互連接的一種度量
內(nèi)聚是一個模塊內(nèi)部各成分之間相關(guān)聯(lián)程度的度量
“高內(nèi)聚,低耦合”從內(nèi)部、外部兩個視角去評估抽象結(jié)果的好壞。這其中也有對應(yīng)的原則和方法論,常規(guī)的套路是:
抽象的方法論(套路)
我想,至此,我們說清楚了前面的那兩個問題:
總結(jié)前面說的所有關(guān)于抽象的內(nèi)容,形成抽象的方法論(套路):
下面這張圖來自于《Thinking in UML》,我覺得這個循環(huán)的過程可以表達(dá)上面這四個點,供大家參考。
如何畫好一張架構(gòu)圖?
回到主題,如果上邊的問題說清楚了,接下來的事情就相對簡單了。對于架構(gòu)圖是什么這個問題,我們可以把之前的等式進(jìn)行延展:架構(gòu)圖 = 架構(gòu)的表達(dá) = 架構(gòu)在不同抽象角度和不同抽象層次的表達(dá),這是一個自然而然的過程。不是先有圖再有業(yè)務(wù)流程、系統(tǒng)設(shè)計和領(lǐng)域模型等,而是相反,用圖來表達(dá)抽象的思考和內(nèi)容。
那么架構(gòu)圖有什么用?給誰看?回答這個問題需要講清楚為什么要畫架構(gòu)圖,同時也需要考慮一個問題就是:架構(gòu)圖是不是越多越好,越詳細(xì)越好?
畫架構(gòu)圖是為了什么?
A picture is worth a thousand words (一圖勝千言),從 Why 層面講,我覺得就是如下兩點:
但是上述兩點其實是非?;\統(tǒng)的信息,如果放在 What 層面,我們必須要考慮架構(gòu)圖面對的“客戶”,不同的客戶有不同的訴求(其實也就是角度和層次),在不同的抽象層次架構(gòu)圖所表達(dá)的信息內(nèi)容可以完全不一樣。以目前團(tuán)隊做的事情為例,架構(gòu)圖的目標(biāo)客戶至少有幾類:
所以畫架構(gòu)圖,我們必須首先明確溝通交流的目的和面向的客戶,只有明確了這兩個點才能更加有針對性的達(dá)成上邊所說的那兩點目標(biāo):解決溝通障礙,提升協(xié)作效率。
怎么畫?
先說分類
架構(gòu)圖分類,本質(zhì)上是從不同的視角,不同的抽象角度去看,作出清晰、簡化的描述,涵蓋特點方面忽略無關(guān)方面。
從業(yè)務(wù)應(yīng)用開發(fā)的維度,一般的抽象層次可以分為:
業(yè)務(wù)全域—>子域—>模塊—>子模塊—>包—>類—>方法
這其中:
當(dāng)然,還有很多其他的分類方式,比如:RUP 4+1,GOGAF9 等等分類方式。單從實踐的角度,我覺得何種分類不是最重要的,最重要的是想清楚面向誰和解決什么訴求,然后思考架構(gòu)圖到底從哪個角度、哪個層次去抽象。我們目前所做的項目,有很時候要去和國外的業(yè)務(wù)專家、技術(shù)專家去溝通,大家也并沒有一個明確的標(biāo)準(zhǔn)定義,表述清楚問題,達(dá)成共識這是最最關(guān)鍵的,至于架構(gòu)圖的粒度、類別、內(nèi)容可以逐步的去完善,去粗取精,迭代優(yōu)化。
再說構(gòu)圖
構(gòu)圖的部分,我們大家都用 UML 畫過類圖,涉及泛化、聚合、組合、依賴等等關(guān)系,分別用不同的虛實線、箭頭樣式進(jìn)行表達(dá)。所以畫架構(gòu)圖需要考慮架構(gòu)圖的組成元素,要保證符合一貫理解,架構(gòu)圖的組成元素可能涉及:
構(gòu)圖最最重要的是需要考慮內(nèi)容術(shù)語一致性問題、碎片化問題、信息粒度大小的問題,以及圖表的外觀問題。
如何評判架構(gòu)圖的好壞
架構(gòu)圖的好壞,我理解主要是兩個方向,一個是需要跳出圖本身去看,業(yè)務(wù)領(lǐng)域的抽象設(shè)計合理性,是否符合“高內(nèi)聚,低耦合”的要求,這個需要回到前文的業(yè)務(wù)建模、系統(tǒng)建模和抽象過程去尋找答案。另外一個方向是圖本身,以下幾個點供參考:
但是,終歸還是那句話,“一張圖片勝過千言萬語”。不管好壞,不管是否美觀,人是視覺動物,用圖表達(dá)可以極大的提升溝通效率,先畫起來吧!
最后也聊聊架構(gòu)師
這是來自于阿白老師的文章《架構(gòu)師到底是做什么的?》,越是琢磨,越覺得深以為然。其中提到了好的架構(gòu)師的畫像和不好的畫像,如下圖,與大家共勉。
從我個人的成長經(jīng)歷看,架構(gòu)師很重要的一點要學(xué)會“權(quán)衡”,既要兼顧當(dāng)下痛點也要符合未來一定時間的發(fā)展,既要保留未來的可擴(kuò)展性也要避免過度設(shè)計。選擇什么樣的時間節(jié)點、什么樣的業(yè)務(wù)場景以及什么樣的架構(gòu)迭代策略至關(guān)重要,這些決策的關(guān)鍵在于判斷和取舍,需要結(jié)合深刻的業(yè)務(wù)思考乃至組織架構(gòu)去做權(quán)衡落地。一點點不算經(jīng)驗的經(jīng)驗:
快速學(xué)習(xí)
快不是一個速度問題,也是一個判斷或者標(biāo)準(zhǔn)問題。面對一個全新業(yè)務(wù)場景,如何能夠識別20%的關(guān)鍵業(yè)務(wù)路徑,關(guān)鍵業(yè)務(wù)痛點,如何短時間把自己變成業(yè)務(wù)專家這是一個架構(gòu)師基本的素質(zhì)。我的一點經(jīng)驗就是要去「吸金式」的思考,帶著問題主動思考,客戶是誰?有什么訴求?需要解決什么樣的問題?我們能提供什么樣的價值?多問為什么?這也需要長時間的刻意訓(xùn)練。
不要屁股決定腦袋
要跨角色、跨層級去看待業(yè)務(wù)問題,這個點容易陷入說教,說實話我自己做得也未必到位。但是時刻提醒自己的思考是否被局限,在哪一個維度,是 Have-do-be,還是 be-do-Have 等等;同時也不斷的在提醒自己永遠(yuǎn)不要屁股決定腦袋。
提升思考能力和對于技術(shù)原理或本質(zhì)的理解
我覺得這是最底層的能力,業(yè)務(wù)開發(fā)中我覺得大的兩個難點:一是邏輯的復(fù)雜性,二是需求的變化性。我們不應(yīng)該大部分時間花在尋找解決方案上,而應(yīng)該花更多的時間在選擇解決方案上。這就要求我們對業(yè)務(wù)全局、行業(yè)深度、技術(shù)視野、技術(shù)深度、業(yè)務(wù)共性、個性特征等等形成自己的認(rèn)知。權(quán)衡取舍,取什么舍什么?該怎么取怎么舍?那個度在哪里?唯有思考,自驅(qū),累積和堅持,勇猛精進(jìn),志愿無倦。
最后的最后
希望這篇文章對大家有幫助,附上最初在考慮這個主題時的構(gòu)思過程及思考路徑,供大家參考。
參考文檔
為什么我們需要架構(gòu)圖(https://new.qq.com/omn/20190131/20190131A16MWK.html)
軟件架構(gòu)圖的藝術(shù) (https://www.infoq.cn/article/crafting-architectural-diagrams)
邏輯架構(gòu)和物理架構(gòu) (https://www.cnblogs.com/dinglang/p/4565378.html)
一篇文章讀懂分層架構(gòu) (https://zhuanlan.zhihu.com/p/40353581)
TOGAF & RUP
(https://www.ibm.com/developerworks/cn/rational/rationaledge/content/feb07/temnenco/index.html)
如何自底向上推導(dǎo)應(yīng)用邏輯架構(gòu)?+如何自頂向下構(gòu)建架構(gòu)?(節(jié)選)
(https://developer.aliyun.com/article/727436)
《大象:Thinking in UML》
《聊聊架構(gòu)》
網(wǎng)站標(biāo)題:如何畫好一張架構(gòu)圖?
文章URL:http://aaarwkj.com/news3/103753.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供做網(wǎng)站、品牌網(wǎng)站建設(shè)、網(wǎng)站營銷、自適應(yīng)網(wǎng)站、網(wǎng)站排名、關(guān)鍵詞優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容