精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

淺談我對(duì)DDD領(lǐng)域驅(qū)動(dòng)設(shè)計(jì)的理解

移動(dòng)開發(fā) 開發(fā)
當(dāng)人們要做一個(gè)軟件系統(tǒng)時(shí),一般總是因?yàn)橛龅搅耸裁磫栴},然后希望通過一個(gè)軟件系統(tǒng)來解決。

從遇到問題開始

當(dāng)人們要做一個(gè)軟件系統(tǒng)時(shí),一般總是因?yàn)橛龅搅耸裁磫栴},然后希望通過一個(gè)軟件系統(tǒng)來解決。

比如,我是一家企業(yè),然后我覺得我現(xiàn)在線下銷售自己的產(chǎn)品還不夠,我希望能夠在線上也能銷售自己的產(chǎn)品。所以,自然而然就想到要做一個(gè)普通電商系統(tǒng),用于實(shí)現(xiàn)在線銷售自己企業(yè)產(chǎn)品的目的。

再比如,我是一家互聯(lián)網(wǎng)公司,公司有很多系統(tǒng)對(duì)外提供服務(wù),面向很多客戶端設(shè)備。但是最近由于各種原因,導(dǎo)致服務(wù)經(jīng)常出故障。所以,我們希望通過各種措施提高服務(wù)的質(zhì)量和穩(wěn)定性。其中的一個(gè)措施就是希望能做一個(gè)灰度發(fā)布的平臺(tái),這個(gè)平臺(tái)可以提供灰度發(fā)布的服務(wù)。然后,當(dāng)某個(gè)業(yè)務(wù)系統(tǒng)做了一些修改并需要發(fā)布時(shí),可以使用我們的灰度發(fā)布平臺(tái)來非常方便的實(shí)現(xiàn)灰度發(fā)布的功能。比如在灰度發(fā)布平臺(tái)上方便的定制允許哪些特定的客戶端才會(huì)訪問新服務(wù),哪些客戶端繼續(xù)使用老服務(wù)。灰度發(fā)布平臺(tái)可以提供各種灰度的策略。有了這樣的灰度發(fā)布機(jī)制,那即便系統(tǒng)的新邏輯有什么問題,受影響的面也不會(huì)很大,在可控范圍內(nèi)。所以,如果公司里的所有對(duì)外提供服務(wù)的系統(tǒng)都接入了灰度平臺(tái),那這些系統(tǒng)的發(fā)布環(huán)節(jié)就可以更加有保障了。

總之,我們做任何一個(gè)軟件系統(tǒng),都是有原因的,否則就沒必要做這個(gè)系統(tǒng),而這個(gè)原因就是我們遇到的問題。所以,通過問題,我們就知道了我們需要一個(gè)什么樣的系統(tǒng),這個(gè)系統(tǒng)解決什么樣的問題。***,我們就很自然的得出了一個(gè)目標(biāo),即知道了自己要什么。比如我要做一個(gè)論壇、一個(gè)博客系統(tǒng)、一個(gè)電商平臺(tái)、一個(gè)灰度發(fā)布系統(tǒng)、一個(gè)IDE、一個(gè)分布式消息隊(duì)列、一個(gè)通信框架,等等。

DDD切入點(diǎn)1 - 理解概念

DDD的全稱為Domain-driven Design,即領(lǐng)域驅(qū)動(dòng)設(shè)計(jì)。下面我從領(lǐng)域、問題域、領(lǐng)域模型、設(shè)計(jì)、驅(qū)動(dòng)這幾個(gè)詞語的含義和聯(lián)系的角度去闡述DDD是如何融入到我們平時(shí)的軟件開發(fā)初期階段的。要理解什么是領(lǐng)域驅(qū)動(dòng)設(shè)計(jì),首先要理解什么是領(lǐng)域,什么是設(shè)計(jì),還有驅(qū)動(dòng)是什么意思,什么驅(qū)動(dòng)什么。

什么是領(lǐng)域(Domain)?

前面我們已經(jīng)清楚的知道我們現(xiàn)在要做一個(gè)什么樣的系統(tǒng),這個(gè)系統(tǒng)需要解決什么問題。我認(rèn)為任何一個(gè)系統(tǒng)都會(huì)屬于某個(gè)特定的領(lǐng)域,比如論壇是一個(gè)領(lǐng)域,只要你想做一個(gè)論壇,那這個(gè)論壇的核心業(yè)務(wù)是確定的,比如都有用戶發(fā)帖、回帖等核心基本功能。比如電商平臺(tái)、普通電商系統(tǒng),這種都屬于網(wǎng)上電商領(lǐng)域,只要是這個(gè)領(lǐng)域的系統(tǒng),那都有商品瀏覽、購物車、下單、減庫存、付款交易等核心環(huán)節(jié)。所以,同一個(gè)領(lǐng)域的系統(tǒng)都具有相同的核心業(yè)務(wù),因?yàn)樗麄円鉀Q的問題的本質(zhì)是類似的。

因此,我們可以推斷出,一個(gè)領(lǐng)域本質(zhì)上可以理解為就是一個(gè)問題域,只要是同一個(gè)領(lǐng)域,那問題域就相同。所以,只要我們確定了系統(tǒng)所屬的領(lǐng)域,那這個(gè)系統(tǒng)的核心業(yè)務(wù),即要解決的關(guān)鍵問題、問題的范圍邊界就基本確定了。通常我們說,要成為一個(gè)領(lǐng)域的專家,必須要在這個(gè)領(lǐng)域深入研究很多年才行。因?yàn)橹挥心阊芯苛撕芏嗄辏悴艜?huì)遇到非常多的該領(lǐng)域的問題,同時(shí)你解決這個(gè)領(lǐng)域中的問題的經(jīng)驗(yàn)也非常豐富。很多時(shí)候,領(lǐng)域?qū)<冶燃夹g(shù)專家更加吃香,比如金融領(lǐng)域的專家。

什么是設(shè)計(jì)(Design)?

DDD中的設(shè)計(jì)主要指領(lǐng)域模型的設(shè)計(jì)。為什么是領(lǐng)域模型的設(shè)計(jì)而不是架構(gòu)設(shè)計(jì)或其他的什么設(shè)計(jì)呢?因?yàn)镈DD是一種基于模型驅(qū)動(dòng)開發(fā)的軟件開發(fā)思想,強(qiáng)調(diào)領(lǐng)域模型是整個(gè)系統(tǒng)的核心,領(lǐng)域模型也是整個(gè)系統(tǒng)的核心價(jià)值所在。每一個(gè)領(lǐng)域,都有一個(gè)對(duì)應(yīng)的領(lǐng)域模型,領(lǐng)域模型能夠很好的幫我們解決復(fù)雜的業(yè)務(wù)問題。

從領(lǐng)域和代碼實(shí)現(xiàn)的角度來理解,領(lǐng)域模型綁定了領(lǐng)域和代碼實(shí)現(xiàn),確保了最終的代碼實(shí)現(xiàn)就一定是解決了領(lǐng)域中的核心問題的。因?yàn)椋?)領(lǐng)域驅(qū)動(dòng)領(lǐng)域模型設(shè)計(jì);2)領(lǐng)域模型驅(qū)動(dòng)代碼實(shí)現(xiàn)。我們只要保證領(lǐng)域模型的設(shè)計(jì)是正確的,就能確定領(lǐng)域模型可以解決領(lǐng)域中的核心問題;同理,我們只要保證代碼實(shí)現(xiàn)是嚴(yán)格按照領(lǐng)域模型的意圖來落地的,那就能保證***出來的代碼能夠解決領(lǐng)域的核心問題的。這個(gè)思路,和傳統(tǒng)的分析、設(shè)計(jì)、編碼這幾個(gè)階段被割裂(并且每個(gè)階段的產(chǎn)物也不同)的軟件開發(fā)方法學(xué)形成鮮明的對(duì)比。

什么是驅(qū)動(dòng)(Driven)?

上面其實(shí)已經(jīng)提到了,就是:1)領(lǐng)域驅(qū)動(dòng)領(lǐng)域模型設(shè)計(jì);2)領(lǐng)域模型驅(qū)動(dòng)代碼實(shí)現(xiàn)。這個(gè)就和我們傳統(tǒng)的數(shù)據(jù)庫驅(qū)動(dòng)開發(fā)的思路形成對(duì)比了。DDD中,我們總是以領(lǐng)域?yàn)檫吔纾治鲱I(lǐng)域中的核心問題(核心關(guān)注點(diǎn)),然后設(shè)計(jì)對(duì)應(yīng)的領(lǐng)域模型,再通過領(lǐng)域模型驅(qū)動(dòng)代碼實(shí)現(xiàn)。而像數(shù)據(jù)庫設(shè)計(jì)、持久化技術(shù)等這些都不是DDD的核心,而是外圍的東西。

領(lǐng)域驅(qū)動(dòng)設(shè)計(jì)(DDD)告訴我們的***價(jià)值我覺得是:當(dāng)我們要開發(fā)一個(gè)系統(tǒng)時(shí),應(yīng)該盡量先把領(lǐng)域模型想清楚,然后再開始動(dòng)手編碼,這樣的系統(tǒng)后期才會(huì)很好維護(hù)。但是,很多項(xiàng)目(尤其是互聯(lián)網(wǎng)項(xiàng)目,為了趕工)都是一開始模型沒想清楚,一上來就開始建表寫代碼,代碼寫的非常冗余,完全是過程是的思考方式,***導(dǎo)致系統(tǒng)非常難以維護(hù)。而且更糟糕的是,出來混總是要還的,前期的領(lǐng)域模型設(shè)計(jì)的不好,不夠抽象,如果你的系統(tǒng)會(huì)長(zhǎng)期需要維護(hù)和適應(yīng)業(yè)務(wù)變化,那后面你一定會(huì)遇到各種問題維護(hù)上的困難,比如數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)不合理,代碼到處冗余,改BUG到處引入新的BUG,新人對(duì)這種代碼上手困難,等。而那時(shí)如果你再想重構(gòu)模型,那要付出的代價(jià)會(huì)比一開始重新開發(fā)還要大,因?yàn)槟氵€要考慮兼容歷史的數(shù)據(jù),數(shù)據(jù)遷移,如何平滑發(fā)布等各種頭疼的問題。所以,就導(dǎo)致我們***天天加班。

雖然,我們都知道這個(gè)道理,但是我也明白,人的習(xí)慣很難改變的,大部分人都很難從面向過程式的想到哪里寫到哪里的思想轉(zhuǎn)變?yōu)榛谙到y(tǒng)化的模型驅(qū)動(dòng)的思維。我想,這或許是DDD很難在中國或國外流行起來的原因吧。但是,我想這不應(yīng)該成為我們放棄學(xué)習(xí)DDD的原因,對(duì)吧!

概念總結(jié):

  1. 領(lǐng)域就是問題域,有邊界,領(lǐng)域中有很多問題;
  2. 任何一個(gè)系統(tǒng)要解決的那個(gè)大問題都對(duì)應(yīng)一個(gè)領(lǐng)域;
  3. 通過建立領(lǐng)域模型來解決領(lǐng)域中的核心問題,模型驅(qū)動(dòng)的思想;
  4. 領(lǐng)域建模的目標(biāo)針對(duì)我們?cè)陬I(lǐng)域中所關(guān)心的問題,即只針對(duì)核心關(guān)注點(diǎn),而不是整個(gè)領(lǐng)域中的所有問題;
  5. 領(lǐng)域模型在設(shè)計(jì)時(shí)應(yīng)考慮一定的抽象性、通用性,以及復(fù)用價(jià)值;
  6. 通過領(lǐng)域模型驅(qū)動(dòng)代碼的實(shí)現(xiàn),確保代碼讓領(lǐng)域模型落地,代碼最終能解決問題;
  7. 領(lǐng)域模型是系統(tǒng)的核心,是領(lǐng)域內(nèi)的業(yè)務(wù)的直接沉淀,具有非常大的業(yè)務(wù)價(jià)值;
  8. 技術(shù)架構(gòu)設(shè)計(jì)或數(shù)據(jù)存儲(chǔ)等是在領(lǐng)域模型的外圍,幫助領(lǐng)域模型進(jìn)行落地;

DDD切入點(diǎn)2 - 理解領(lǐng)域、拆分領(lǐng)域、細(xì)化領(lǐng)域

理解領(lǐng)域知識(shí)是基礎(chǔ)

上面我們通過***步,雖然我們明確了要做一個(gè)什么樣的系統(tǒng),該系統(tǒng)主要解決什么問題,但是就這樣我們還無法開始進(jìn)行實(shí)際的需求分析和模型設(shè)計(jì),我們還必須將我們的問題進(jìn)行拆分,需求進(jìn)行細(xì)化。有些時(shí)候,需求方,即提出問題的人,很可能自己不清楚具體想要什么。他只知道一個(gè)概念,一個(gè)大的目標(biāo)。比如他只知道要做一個(gè)股票交易系統(tǒng),一個(gè)灰度發(fā)布系統(tǒng),一個(gè)電商平臺(tái),一個(gè)開發(fā)工具,等。但是他不清楚這些系統(tǒng)應(yīng)該具體做成什么樣子。這個(gè)時(shí)候,我認(rèn)為領(lǐng)域?qū)<揖头浅V匾耍珼DD也非常強(qiáng)調(diào)領(lǐng)域?qū)<业闹匾浴R驗(yàn)轭I(lǐng)域?qū)<覍?duì)這個(gè)領(lǐng)域非常了解,對(duì)領(lǐng)域內(nèi)的各種業(yè)務(wù)場(chǎng)景和各種業(yè)務(wù)規(guī)則也非常清楚,總之,對(duì)這個(gè)領(lǐng)域內(nèi)的一切業(yè)務(wù)相關(guān)的知識(shí)都非常了解。所以,他們自然就有能力表達(dá)出系統(tǒng)該做成什么樣子。所以,要知道一個(gè)系統(tǒng)到底該做成什么樣子,到底哪些是核心業(yè)務(wù)關(guān)注點(diǎn),只能靠沉淀領(lǐng)域內(nèi)的各種知識(shí),別無他法。因此,假設(shè)你現(xiàn)在打算做一個(gè)電商平臺(tái),但是你對(duì)這個(gè)領(lǐng)域沒什么了解,那你一定得先去了解下該領(lǐng)域內(nèi)主流的電商平臺(tái),比如淘寶、天貓、京東、亞馬遜等。這個(gè)了解的過程就是你沉淀領(lǐng)域知識(shí)的過程。如果你不了解,就算你領(lǐng)域建模的能力再強(qiáng),各種技術(shù)架構(gòu)能力再強(qiáng)也是使不上力。領(lǐng)域?qū)<也皇悄硞€(gè)固定的角色,而是某一類人,這類人對(duì)這個(gè)領(lǐng)域非常了解。比如,一個(gè)開發(fā)人員也可以是一個(gè)領(lǐng)域?qū)<摇<僭O(shè)你在一個(gè)公司開發(fā)和維護(hù)一個(gè)系統(tǒng)已經(jīng)好幾年了,但是這個(gè)系統(tǒng)的產(chǎn)品經(jīng)理(PD)可能已經(jīng)換過好幾任了,這種情況下,我相信這幾任產(chǎn)品經(jīng)理都沒有比你更熟悉這個(gè)領(lǐng)域。

拆分領(lǐng)域

上面我們明白了,領(lǐng)域建模的基礎(chǔ)是要先理解領(lǐng)域,讓自己成為領(lǐng)域?qū)<摇H绻龅搅诉@點(diǎn),我們就打好了堅(jiān)實(shí)的基礎(chǔ)了。但是,有時(shí)一個(gè)領(lǐng)域往往太復(fù)雜,涉及到的領(lǐng)域概念、業(yè)務(wù)規(guī)則、交互流程太多,導(dǎo)致我們沒辦法直接針對(duì)這個(gè)大的領(lǐng)域進(jìn)行領(lǐng)域建模。所以,我們需要將領(lǐng)域進(jìn)行拆分,本質(zhì)上就是把大問題拆分為小問題,然后各個(gè)擊破的思路。然后既然把一個(gè)大的領(lǐng)域劃分為了多個(gè)小的領(lǐng)域(子域),那最關(guān)鍵的就是要理清每個(gè)子域的邊界;然后要搞清楚哪些子域是核心子域,哪些是非核心子域,哪些是公共支撐子域;然后,還要思考子域之間的聯(lián)系是什么。那么,我們?cè)撊绾蝿澐肿佑蚰兀课业膫€(gè)人看法是從業(yè)務(wù)相關(guān)性的角度去思考,也就是我們平時(shí)說的按業(yè)務(wù)功能為出發(fā)點(diǎn)進(jìn)行劃分。還是拿經(jīng)典的電商系統(tǒng)來分析,通常一個(gè)電商系統(tǒng)都會(huì)包含好幾個(gè)大塊,比如:

  • 會(huì)員中心:負(fù)責(zé)用戶賬號(hào)登錄、用戶信息的管理;
  • 商品中心:負(fù)責(zé)商品的展示、導(dǎo)航、維護(hù);
  • 訂單中心:負(fù)責(zé)訂單的生成和生命周期管理;
  • 交易中心:負(fù)責(zé)交易相關(guān)的業(yè)務(wù);
  • 庫存中心:負(fù)責(zé)維護(hù)商品的庫存;
  • 促銷中心:負(fù)責(zé)各種促銷活動(dòng)的支持;

上面這些中心看起來很自然,因?yàn)榇蠹覍?duì)電子商務(wù)的這個(gè)領(lǐng)域都已經(jīng)非常熟悉了,所以都沒什么疑問,好像很自然的樣子。所以,領(lǐng)域劃分是不是就是沒什么挑戰(zhàn)了呢?顯然不是。之所以我們覺得子域劃分很簡(jiǎn)單,是因?yàn)槲覀儗?duì)整個(gè)大領(lǐng)域非常了解了。如果我們遇到一個(gè)冷門的領(lǐng)域,就沒辦法這么容易的去劃分子域了。這就需要我們先去努力理解領(lǐng)域內(nèi)的知識(shí)。所以,我個(gè)人從來不相信什么子域劃分的技巧什么的東西,因?yàn)槲矣X得這個(gè)工作沒有任何訣竅可以使用。當(dāng)我們不了解一個(gè)東西的時(shí)候,如何去拆解它?當(dāng)我們對(duì)整個(gè)領(lǐng)域有一定的熟悉了,了解了領(lǐng)域內(nèi)的相關(guān)業(yè)務(wù)的本質(zhì)和關(guān)系,我們就自然而然的能劃分出合理的子域了。不過并不是所有的系統(tǒng)都需要?jiǎng)澐肿佑虻模行┫到y(tǒng)只是解決一個(gè)小問題,這個(gè)問題不復(fù)雜,可能只有一兩個(gè)核心概念。所以,這種系統(tǒng)完全不需要再劃分子域。但不是絕對(duì)的,當(dāng)一個(gè)領(lǐng)域,我們的關(guān)注點(diǎn)越來越多,每個(gè)關(guān)注點(diǎn)我們關(guān)注的信息越來越多的時(shí)候,我們會(huì)不由自主的去進(jìn)一步的劃分子域。比如,也許我們一開始將商品和商品的庫存都放在商品中心里,但是后來由于庫存的維護(hù)越來越復(fù)雜,導(dǎo)致揉在一起對(duì)我們的系統(tǒng)維護(hù)帶來一定的困難時(shí),我們就會(huì)考慮將兩者進(jìn)行拆分,這個(gè)就是所謂的業(yè)務(wù)垂直分割。

細(xì)化子域

通過上面的兩步,我們了解了領(lǐng)域里的知識(shí),也對(duì)領(lǐng)域進(jìn)行了子域劃分。但這樣還不夠,憑這些我們還無法進(jìn)行后續(xù)的領(lǐng)域模型設(shè)計(jì)。我們還必須再進(jìn)一步細(xì)化每個(gè)子域,進(jìn)一步明確每個(gè)子域的核心關(guān)注點(diǎn),即需求細(xì)化。我覺得我們需要細(xì)化的方面有以下幾點(diǎn):

  1. 梳理領(lǐng)域概念:梳理出領(lǐng)域內(nèi)我們關(guān)注的概念、概念的關(guān)系,并統(tǒng)一交流詞匯,形成統(tǒng)一語言;
  2. 梳理業(yè)務(wù)規(guī)則:梳理出領(lǐng)域內(nèi)我們關(guān)注的各種業(yè)務(wù)規(guī)則,DDD中叫不變性(invariants),比如唯一性規(guī)則,余額不能小于零等;
  3. 梳理業(yè)務(wù)場(chǎng)景:梳理出領(lǐng)域內(nèi)的核心業(yè)務(wù)場(chǎng)景,比如電商平臺(tái)中的加入購物車、提交訂單、發(fā)起付款等核心業(yè)務(wù)場(chǎng)景;
  4. 梳理業(yè)務(wù)流程:梳理出領(lǐng)域內(nèi)的關(guān)鍵業(yè)務(wù)流程,比如訂單處理流程,退款流程等;

從上面這4個(gè)方面,我們從領(lǐng)域概念、業(yè)務(wù)規(guī)則、交互場(chǎng)景、業(yè)務(wù)流程等維度梳理了我們到底要什么,整理了整個(gè)系統(tǒng)應(yīng)該具備的功能。這個(gè)工作我覺得是一個(gè)非常具有創(chuàng)造性和有難度的工作。我們一方面會(huì)主觀的定義我們想要什么;另一方面,我們還會(huì)思考我們要的東西的合理性。我認(rèn)為這個(gè)就是產(chǎn)品經(jīng)理的工作,產(chǎn)品經(jīng)理必須要負(fù)起職責(zé),把他的產(chǎn)品充分設(shè)計(jì)好,從各個(gè)方面去考慮,如何設(shè)計(jì)一個(gè)產(chǎn)品,才能更好的解決用戶的核心訴求,即領(lǐng)域內(nèi)的核心問題。如果對(duì)領(lǐng)域不夠了解,如果想不清楚用戶到底要什么,如果思考問題不夠全面,談何設(shè)計(jì)出一個(gè)合理的產(chǎn)品呢?

關(guān)于領(lǐng)域概念的梳理,我覺得可以采用四色原型分析法,這個(gè)分析法通過系統(tǒng)的方法,將概念劃分為不同的種類,為不同種類的概念標(biāo)注不同的顏色。然后將這些概念有機(jī)的組合起來,從而讓我們可以清晰的分析出概念和概念之間的關(guān)系。有興趣的同學(xué)可以在網(wǎng)上搜索下四色原型。

注意:上面我說的這四點(diǎn),重點(diǎn)是梳理出我們要什么功能,而不是思考如何實(shí)現(xiàn)這些功能,如何實(shí)現(xiàn)是軟件設(shè)計(jì)人員的職責(zé)。

DDD切入點(diǎn)3 - 領(lǐng)域模型設(shè)計(jì)

這部分內(nèi)容,我想學(xué)習(xí)DDD的人都很熟悉了。DDD原著中提出了很多實(shí)用的建模工具:聚合、實(shí)體、值對(duì)象、工廠、倉儲(chǔ)、領(lǐng)域服務(wù)、領(lǐng)域事件。我們可以使用這些工具,來設(shè)計(jì)每一個(gè)子域的領(lǐng)域模型。最終通過領(lǐng)域模型圖將設(shè)計(jì)沉淀下來。要使用這些工具,首先就要理解每個(gè)工具的含義和使用場(chǎng)景。不要以為很簡(jiǎn)單哦,比如聚合的劃分就是一個(gè)非常具有藝術(shù)的活。同一個(gè)系統(tǒng),不同的人設(shè)計(jì)出來的聚合是完全不同的。而且很有可能高手之間的***設(shè)計(jì)出來的差別反而更大,實(shí)際上我認(rèn)為是世界觀的相互碰撞,呵呵。所以,要領(lǐng)域建模,我覺得每個(gè)人都應(yīng)該去學(xué)學(xué)哲學(xué)知識(shí),這有助于我們更好的認(rèn)識(shí)世界,更好的理解事物的本質(zhì)。

關(guān)于這些建模工具的概念和如何運(yùn)用我就不多展開了,我博客里也有很多這方面的介紹。下面我再講一下我認(rèn)為比較重要的東西,比如到底該如何領(lǐng)域建模?步驟應(yīng)該是怎么樣的?

領(lǐng)域建模的方法

通過上面我介紹的細(xì)化子域的內(nèi)容,現(xiàn)在再來談該如何領(lǐng)域建模,我覺得就方便很多了。我的主要方法是:

  1. 劃分好邊界上下文,通常每個(gè)子域(sub domain)對(duì)應(yīng)一個(gè)邊界上下文(bounded context),同一個(gè)邊界上下文中的概念是明確的,沒有任何歧義;
  2. 在每個(gè)邊界上下文中設(shè)計(jì)領(lǐng)域模型,具體的領(lǐng)域模型設(shè)計(jì)方法有很多種,如以場(chǎng)景為出發(fā)點(diǎn)的四色原型分析法,或者我早期寫的這篇文章;這個(gè)步驟最核心的就是找出聚合根,并找出每個(gè)聚合根包含的信息;關(guān)于如何設(shè)計(jì)聚合,可以看一下我寫的這篇文章;
  3. 畫出領(lǐng)域模型圖,圈出每個(gè)模型中的聚合邊界;
  4. 設(shè)計(jì)領(lǐng)域模型時(shí),要考慮該領(lǐng)域模型是否滿足業(yè)務(wù)規(guī)則,同時(shí)還要綜合考慮技術(shù)實(shí)現(xiàn)等問題,比如并發(fā)問題;領(lǐng)域模型不是概念模型,概念模型不關(guān)注技術(shù)實(shí)現(xiàn),領(lǐng)域模型關(guān)心;所以領(lǐng)域模型才能直接指導(dǎo)編碼實(shí)現(xiàn);
  5. 思考領(lǐng)域模型是如何在業(yè)務(wù)場(chǎng)景中發(fā)揮作用的,以及是如何參與到業(yè)務(wù)流程的每個(gè)環(huán)節(jié)的;
  6. 場(chǎng)景走查,確認(rèn)領(lǐng)域模型是否能滿足領(lǐng)域中的業(yè)務(wù)場(chǎng)景和業(yè)務(wù)流程;
  7. 模型持續(xù)重構(gòu)、完善、精煉;

領(lǐng)域模型的核心作用:

  1. 抽象了領(lǐng)域內(nèi)的核心概念,并建立概念之間的關(guān)系;
  2. 領(lǐng)域模型承擔(dān)了領(lǐng)域內(nèi)的狀態(tài)的維護(hù);
  3. 領(lǐng)域模型維護(hù)了領(lǐng)域內(nèi)的數(shù)據(jù)之間的業(yè)務(wù)規(guī)則,數(shù)據(jù)一致性;

下圖是我最近做個(gè)一個(gè)普通電商系統(tǒng)的商品中心的領(lǐng)域模型圖,給大家參考:

 

普通電商系統(tǒng)的商品中心的領(lǐng)域模型圖

領(lǐng)域模型設(shè)計(jì)只是軟件設(shè)計(jì)中的一小部分

需要特別注意的是,領(lǐng)域模型設(shè)計(jì)只是整個(gè)軟件設(shè)計(jì)中的很小一部分。除了領(lǐng)域模型設(shè)計(jì)之外,要落地一個(gè)系統(tǒng),我們還有非常多的其他設(shè)計(jì)要做,比如:

  • 容量規(guī)劃
  • 架構(gòu)設(shè)計(jì)
  • 數(shù)據(jù)庫設(shè)計(jì)
  • 緩存設(shè)計(jì)
  • 框架選型
  • 發(fā)布方案
  • 數(shù)據(jù)遷移、同步方案
  • 分庫分表方案
  • 回滾方案
  • 高并發(fā)解決方案
  • 一致性選型
  • 性能壓測(cè)方案
  • 監(jiān)控報(bào)警方案

等等。上面這些都需要我們平時(shí)的大量學(xué)習(xí)和積累。作為一個(gè)合格的開發(fā)人員或架構(gòu)師,我覺得除了要會(huì)DDD領(lǐng)域驅(qū)動(dòng)設(shè)計(jì),還要會(huì)上面這么多的技術(shù)能力,確實(shí)是非常不容易的。所以,千萬不要以為會(huì)DDD了就以為自己很牛逼,實(shí)際上你會(huì)的只是軟件設(shè)計(jì)中的冰山一角而已。

總結(jié)

本文的重點(diǎn)是基于我個(gè)人對(duì)DDD的一些理解,希望能整理出一些自己總結(jié)出來的一些感悟和經(jīng)驗(yàn),并分享給大家。我相信很多人已經(jīng)看過太多DDD書上的東西,我總是感覺書上的東西看似都太”正規(guī)“,很多時(shí)候我們讀了之后很難消化,就算理解了書里的內(nèi)容,當(dāng)我們想要運(yùn)用到實(shí)踐中時(shí),總是感覺無從下手。本文希望通過通俗易懂的文字,介紹了一部分我對(duì)DDD的學(xué)習(xí)感悟和實(shí)踐心得,希望能給大家一些啟發(fā)和幫助。

責(zé)任編輯:張子龍 來源: 博客園
相關(guān)推薦

2021-09-08 09:22:23

領(lǐng)域驅(qū)動(dòng)設(shè)計(jì)

2021-10-09 11:54:46

DDD微服務(wù)業(yè)務(wù)

2024-11-27 15:33:17

軟件架構(gòu)DDD

2020-09-02 08:12:05

CodeDDD代碼

2024-12-31 11:05:07

2023-01-09 09:00:00

樹服務(wù)架構(gòu)驅(qū)動(dòng)決策

2014-09-26 10:00:25

驅(qū)動(dòng)設(shè)計(jì)DDD領(lǐng)域

2024-11-08 08:37:25

2023-02-15 13:50:58

DDD戰(zhàn)略設(shè)計(jì)

2024-07-17 08:12:06

2019-01-02 05:55:30

領(lǐng)域驅(qū)動(dòng)軟件復(fù)雜度

2020-08-27 08:31:11

DDD可視化模型

2022-07-17 07:37:29

微服務(wù)DDD工程化落地

2025-10-10 02:12:00

性能優(yōu)化C#ORM

2016-09-18 20:53:16

JavaScript閉包前端

2009-04-24 09:43:09

.NETASP.NET框架

2011-03-22 10:16:48

程序員

2024-09-25 08:00:00

領(lǐng)域驅(qū)動(dòng)設(shè)計(jì)軟件開發(fā)

2013-07-11 10:37:20

Java內(nèi)存模型

2017-05-24 10:12:54

前端FlexboxCSS3
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

伊人久久视频| 欧美极品少妇与黑人| aaa毛片在线观看| 国产日本在线| 国产伦精品一区二区三区免费迷| 久久久久久有精品国产| 精品成人av一区二区三区| 农村妇女一区二区| 性感美女久久精品| 在线观看成人一级片| 人人妻人人澡人人爽精品日本| 天使萌一区二区三区免费观看| 久久久91精品国产| av网站免费在线播放| 亚洲网站三级| 欧美性jizz18性欧美| 成年人三级视频| 国产天堂在线| 99精品黄色片免费大全| 91精品久久久久久久久| 亚洲男人的天堂在线视频| 久久久久久久久久久久久久久久久久| 国产在线视频福利| 青草综合视频| 午夜在线成人av| 亚洲欧洲一区二区| 日本黄色不卡视频| 黄页网站大全一区二区| 久久亚洲电影| 最好看的2019年中文视频 | 亚洲图片另类小说| av综合网址| 91麻豆精品国产自产在线| 亚洲国产精品久久久久婷蜜芽| 宅男网站在线免费观看| 国产精品久久久久影院色老大| 久久久久无码国产精品一区| 国产91免费在线观看| 国产一区二区三区在线观看精品 | 国产精品女同一区二区三区| 久久久久久亚洲精品不卡4k岛国 | 成人免费三级在线| 91免费观看| 国产女主播福利| 美女精品一区二区| 国产精品视频一区国模私拍| 久久久久久久极品| 宅男噜噜噜66国产日韩在线观看| 久久久久国产精品免费| 国产精品久久久久久久精| 手机在线一区二区三区| 中文字幕在线精品| 黑人と日本人の交わりビデオ| 啪啪亚洲精品| 一本一本久久a久久精品综合小说 一本一本久久a久久精品牛牛影视 | 欧美一区二区三区婷婷月色| 污污网站在线观看视频| 啪啪av大全导航福利综合导航| 欧美日韩一区二区三区免费看| 亚洲成人av免费看| 欧美黄页在线免费观看| 欧美一区二区三区在线| 曰本三级日本三级日本三级| 亚洲国产精品免费视频| 日韩欧美123| 理论片大全免费理伦片| 免费看久久久| 亚洲品质视频自拍网| 懂色av蜜桃av| 天天射天天综合网| 欧美人与性动交| xxxx 国产| 久久www成人_看片免费不卡| 国产精品国产三级国产aⅴ浪潮| 18国产免费视频| 精品在线一区二区三区| 2014亚洲精品| 日本一二三区在线视频| 国产精品久久久久久久裸模 | 国产精品剧情一区二区在线观看| 亚洲精品日日夜夜| 国产精品裸体瑜伽视频| 都市激情亚洲综合| 欧美日本不卡视频| 日本人妻一区二区三区| 亚洲性视频大全| 日韩在线观看网址| 国产一级理论片| 久久九九免费| 99热国产免费| 国产黄色片在线播放| 亚洲精品视频在线观看免费| 欧美s码亚洲码精品m码| 亚洲精品555| 欧美草草影院在线视频| 亚洲码无人客一区二区三区| 国产精品99久久精品| 国语自产精品视频在线看抢先版图片| www.色国产| 国产成人精品一区二区三区四区| 欧美极品视频一区二区三区| 成人日韩欧美| 色婷婷综合久久久| 91成人在线观看喷潮蘑菇| 国产乱码精品一区二区亚洲| 欧美激情一区二区三区在线视频观看 | 性高潮久久久久久久| 中文字幕一区二区三区在线视频| 欧美一性一乱一交一视频| 国产乱叫456在线| 久久综合久久综合久久| 六月婷婷激情网| 欧美二三四区| 精品国产网站在线观看| 成人信息集中地| 亚洲在线免费| 岛国视频一区| 久久精品视频免费看| 色综合久久中文字幕| 国产精品99精品无码视亚| 成人三级视频| 日本中文字幕成人| 日本美女一级片| 亚洲另类一区二区| 亚洲老女人av| 欧美激情在线免费| 97视频免费在线观看| 99免费在线视频| 国产精品美女久久久久久久| 亚洲中文字幕无码中文字| 这里视频有精品| 欧美成人精品在线观看| 91麻豆成人精品国产免费网站| 久久美女艺术照精彩视频福利播放| www.欧美黄色| eeuss国产一区二区三区四区| 中文字幕欧美日韩| 免费黄色片视频| 国产亚洲欧美色| 干日本少妇首页| 任我爽精品视频在线播放| 国模视频一区二区三区| 亚洲精品久久久蜜桃动漫| 亚洲男帅同性gay1069| 在线黄色免费看| 日韩成人影院| 国产欧美久久一区二区| 二区在线视频| 欧美色中文字幕| 91免费在线看片| 蜜芽一区二区三区| 一级特黄录像免费播放全99| 成人在线视频免费| 久久精品视频免费播放| 97人妻精品一区二区三区软件| 国产精品免费av| 激情黄色小视频| 五月天综合网站| 97视频热人人精品| 国内高清免费在线视频| 精品国产乱码久久| 国产精品久久久久久久妇| a美女胸又www黄视频久久| 国产美女网站在线观看| 无码日韩精品一区二区免费| 日韩av电影中文字幕| 经典三级在线| 欧美日韩免费高清一区色橹橹| 日本女人性生活视频| 国产精品资源站在线| 国产精品va在线观看无码| 欧美调教视频| 国产精品老牛影院在线观看| 成人video亚洲精品| 欧美成人伊人久久综合网| 日本一级黄色大片| 国产日产欧美精品一区二区三区| 手机av在线免费| 欧美日韩 国产精品| 欧洲高清一区二区| 91精品国产九九九久久久亚洲| 国产又粗又大又黄| 亚洲欧美一区二区久久| 男人网站在线观看| 久久综合导航| 在线日韩av永久免费观看| 我要色综合中文字幕| 日本欧美爱爱爱| gogo在线观看| 亚洲精品视频网上网址在线观看| 亚洲一级视频在线观看| 亚洲中国最大av网站| 实拍女处破www免费看| 久久99精品国产麻豆婷婷洗澡| 日韩人妻无码精品久久久不卡| 欧美三级情趣内衣| 国产超碰91| 久久99国产精品二区高清软件| 欧美精品福利视频| 1024国产在线| 亚洲精品v欧美精品v日韩精品| 91麻豆国产在线| 一本色道久久综合亚洲91 | 第一区免费在线观看| 亚洲高清自拍| 精品一区二区成人免费视频| 亚洲警察之高压线| 91久久精品一区二区别| 韩日一区二区| 91精品国产沙发| jizz性欧美| 国产午夜精品全部视频播放| 欧美一级特黄aaaaaa大片在线观看| 欧美日韩在线播放一区| 成人在线免费看视频| 亚洲免费看黄网站| 免费成人深夜天涯网站| 91在线视频免费观看| 原创真实夫妻啪啪av| 蜜臀久久久久久久| 国产v亚洲v天堂无码久久久| 亚洲调教视频在线观看| 中文字幕日韩一区二区三区不卡| 色综合综合网| 欧美日韩电影一区二区| 欧美久久香蕉| 国产日韩欧美一区二区| 一区二区三区国产好| 成人夜晚看av| 色狠狠一区二区三区| 国产精品久久久久久久久久免费| 在线免费三级电影网站| 久久免费观看视频| 久草成色在线| 欧美美最猛性xxxxxx| www久久日com| 美日韩在线视频| 国产鲁鲁视频在线观看特色| 色先锋资源久久综合5566| yourporn在线观看中文站| 亚洲女人天堂网| 日本福利片高清在线观看| 亚洲精品美女在线| 五月天久久久久久| 日韩av网址在线| 四虎国产精品永远| 精品亚洲aⅴ在线观看| 可以在线观看的av| 精品视频在线播放免| 免费资源在线观看| 亚洲欧美一区二区三区四区| 久久伊伊香蕉| 中文字幕日本欧美| 美女羞羞视频在线观看| 久久高清视频免费| 羞羞网站在线免费观看| 欧美激情视频一区| 僵尸再翻生在线观看| 日韩av片免费在线观看| 国产精品亚洲d| 国产日韩专区在线| 日韩精品成人在线观看| 国产精品日韩高清| 亚洲人和日本人hd| 手机成人在线| 亚洲天天影视网| 福利视频免费在线观看| 国产日韩综合| 一区二区三区 日韩| 黑人巨大精品欧美黑白配亚洲| 精产国品一二三区| www.欧美色图| 手机看片福利视频| 亚洲精品中文字幕乱码三区| 99免费在线观看| 91久久一区二区| 国产乱人乱偷精品视频| 欧美精品一区二区三区蜜臀| 日韩av成人| 久久最新资源网| 韩国精品一区| 91精品久久久久久久久久久久久久 | 欧美亚一区二区| 精品人妻av一区二区三区| 日韩av综合网站| 欧美成人高清在线| 国内精品久久久久| av成人在线播放| 国产超碰91| 久久成人综合| 国产特级淫片高清视频| 另类综合日韩欧美亚洲| 亚洲麻豆一区二区三区| 国产亚洲欧美中文| 久久国产在线观看| 欧美日韩在线免费视频| 蜜桃av噜噜一区二区三区麻豆| 夜夜嗨av一区二区三区免费区| 欧洲在线视频| 国产人妖伪娘一区91| 老司机成人在线| 超碰在线免费观看97| 欧美亚洲三级| 黑人巨大猛交丰满少妇| 国产欧美日韩三级| 日韩欧美a级片| 在线综合+亚洲+欧美中文字幕| 欧美成人片在线| 欧美精品电影在线| 不卡的国产精品| 色播亚洲婷婷| 亚洲美女毛片| www.偷拍.com| 中文字幕中文字幕在线一区| 99久久精品国产亚洲| 欧美va天堂va视频va在线| 日本中文在线| 国产成人激情视频| 久久夜色电影| 日韩伦理在线免费观看| 国产精品综合av一区二区国产馆| 午夜时刻免费入口| 欧美日韩视频免费播放| 国精产品一品二品国精品69xx | 成人短视频在线观看免费| 久久精品国产亚洲aⅴ| 女人又爽又黄免费女仆| 亚洲午夜激情av| 精品久久久免费视频| 久久精品国产清自在天天线| 精品69视频一区二区三区| 欧美视频1区| 午夜一区不卡| 蜜桃精品成人影片| 丰满岳妇乱一区二区三区| 色综合视频在线| 久久久之久亚州精品露出| 日韩中文在线| 波多野结衣av一区二区全免费观看 | 精品资源在线看| 欧洲成人午夜免费大片| 日韩精品亚洲aⅴ在线影院| ww国产内射精品后入国产| 99久久久久免费精品国产| 国产乡下妇女做爰视频| 亚洲精品一区在线观看| 动漫一区二区| 精品一区国产| 丝袜亚洲另类欧美| 一区二区三区四区免费| 91福利精品视频| 亚洲欧美视频一区二区| 成人a在线观看| 亚洲网色网站| 亚洲色图欧美日韩| 色婷婷综合中文久久一本| 黄色软件在线观看| 国产精品视频永久免费播放| 91九色精品| 毛茸茸free性熟hd| 欧美日韩午夜剧场| 国产人成在线视频| 成人午夜在线影院| 欧美日韩伊人| av直播在线观看| 欧美三级三级三级爽爽爽| 黄色免费在线看| 国产美女99p| 麻豆久久婷婷| 欧美风情第一页| 亚洲成人av中文字幕| 国产精品久久久久av电视剧| 伊甸园精品99久久久久久| 国产成人免费av在线| 日韩精品乱码久久久久久| 伊人久久精品视频| 国产一区二区| 黄色动漫网站入口| 亚洲欧洲99久久| 神马午夜电影一区二区三区在线观看| 日本一区二区三区在线播放| 围产精品久久久久久久| 免费黄色三级网站| 精品视频一区 二区 三区| 91一区二区三区在线| 久久国产精品免费一区| 久久99久久99| 偷偷操不一样的久久| 精品国产区一区二区三区在线观看| 激情av综合| 无尽裸体动漫2d在线观看| 亚洲18色成人| 一广人看www在线观看免费视频| 高清av免费一区中文字幕| 免费人成黄页网站在线一区二区| 久久av高潮av无码av喷吹| 一区二区中文字幕| 国产亚洲精品美女久久| 最新免费av网址| 欧美亚洲综合网|