ddd不是一種架構(gòu)風(fēng)格,而是一種方法論,什么是方法論,每個(gè)人按照自己的想法來設(shè)計(jì)就是一套方法論;ddd是一種業(yè)務(wù)比較認(rèn)可,對(duì)于微服務(wù)拆分的一種方法論。
微服務(wù)區(qū)別于系統(tǒng),服務(wù)是一組想對(duì)較小且獨(dú)立功能單元,是用戶感知最小功能集。DDD計(jì)的模型中具有邊界的最小原子是聚合,聚合和聚合之間由于只通過聚合根進(jìn)行關(guān)聯(lián),所以當(dāng)需要把一個(gè)聚合根從一個(gè)限界上下文移動(dòng)到另外一個(gè)限界上下文的時(shí)候,非常低的移動(dòng)成本可以很容易地對(duì)微服務(wù)進(jìn)行重構(gòu)。微服務(wù)和ddd的理念不謀而合,在微服務(wù)的大環(huán)境下ddd的流行是趨勢(shì)。
固化思維,從學(xué)校到工作,從學(xué)習(xí)到開源架構(gòu)都是采取這種MVC架構(gòu);
很多行業(yè)是基于傳統(tǒng)行業(yè)進(jìn)行項(xiàng)目改造,只是中間件用了微服務(wù)相關(guān),但是業(yè)務(wù)沒有明顯的拆分依據(jù),換湯不換藥;
資源成本,基于ddd的拆分成本比較高,主要體現(xiàn)在事件風(fēng)暴、領(lǐng)域劃分、實(shí)體聚合,上下文邊界確定;對(duì)于企業(yè)來說,一個(gè)人能搞定的,不需要花大量的人力,時(shí)間去做規(guī)劃;
三層架構(gòu)屬于貧血模型,雖然不符合面向?qū)ο缶幊趟枷?,架?gòu)結(jié)構(gòu)比較簡(jiǎn)單,上手容易。
MVC和DDD主要的區(qū)別在Service層,主要區(qū)別:
MVC:Service 實(shí)現(xiàn)全量業(yè)務(wù)邏輯,BO(Business Object)保存業(yè)務(wù)對(duì)象,屬于貧血模型;
DDD:Service 實(shí)現(xiàn)少量業(yè)務(wù)邏輯,DO(Domain Object) 包含聚合跟、聚合、實(shí)體、值對(duì)象,從技術(shù)上來看就是實(shí)體,里面有相關(guān)領(lǐng)域的行為、動(dòng)作、屬性、依賴關(guān)系,屬性充血模型。
* 領(lǐng)域: 領(lǐng)域是DDD中最大的概念,主要確定邊界范圍,領(lǐng)域又分為核心域(核心業(yè)務(wù)邏輯)、通用域(公共業(yè)務(wù)邏輯)、支撐域(基礎(chǔ)第三方業(yè)務(wù)邏輯);
界限上下文:在界限上下文中要建立通用語言,望文生義,就是大家都看得到,認(rèn)可的叫法就是通用語言;界限上下文主要是來確定領(lǐng)域邊界;
聚合根:聚合根式一個(gè)根實(shí)體,里面包含了許多聚合,而且該聚合根有唯一標(biāo)識(shí),可以協(xié)調(diào)里面的每個(gè)聚合,外部訪問只能根據(jù)聚合根的唯一標(biāo)識(shí)進(jìn)行訪問里面的私有內(nèi)容;
聚合:聚合是一個(gè)整體,把所有的實(shí)體和值對(duì)象組織起來,做到一個(gè)聚合的作用,確保領(lǐng)域在執(zhí)行邏輯的時(shí)候,確定數(shù)據(jù)一致性,從設(shè)計(jì)上避免數(shù)據(jù)不一致性;
實(shí)體:整體概念的多個(gè)屬性歸集到的屬性集合,有唯一標(biāo)識(shí)id,實(shí)體是實(shí)實(shí)在在的業(yè)務(wù)對(duì)象,具有業(yè)務(wù)屬性、行為和業(yè)務(wù)邏輯;
值對(duì)象:若干個(gè)屬性的集合,只有數(shù)據(jù)初始化操作和有限的不涉及修改數(shù)據(jù)的行為,不包含業(yè)務(wù)邏輯
采用風(fēng)暴事件,根據(jù)句業(yè)務(wù)行為,找過過程中發(fā)生行為的實(shí)體和值對(duì)象;
在眾多實(shí)體中選出合適的作為聚合根,挑選依據(jù)主要是否有獨(dú)立的生命周期和全局唯一的ID,是否可以修改或創(chuàng)建其它對(duì)象;
根據(jù)業(yè)務(wù)單一職責(zé)和高內(nèi)聚原則,找出于聚合根關(guān)聯(lián)的實(shí)體和值對(duì)象;
在聚合內(nèi)根據(jù)聚合根、實(shí)體、值對(duì)象,畫出對(duì)象引用模型和依賴關(guān)系模型;
多個(gè)聚合根據(jù)業(yè)務(wù)語義和上下文劃分到一個(gè)上下文界面,也就是一個(gè)小的微服務(wù)。
本文章參考:歐創(chuàng)新的DDD專欄
本文由博客一文多發(fā)平臺(tái) OpenWrite 發(fā)布!
聯(lián)系客服