掃二維碼與項(xiàng)目經(jīng)理溝通
我們在微信上24小時(shí)期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
大家看到的這張架構(gòu)圖并不是空穴來潮,它是通過不斷演變出來的,我們要從DDD四層架構(gòu)、微服務(wù)架構(gòu)兩個(gè)維度去融合理解。

10年積累的成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有陳倉免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
這里的DDD四層架構(gòu)適用于單個(gè)服務(wù)的工程架構(gòu)(如圖中的左下部分),就是單體應(yīng)用的DDD四層架構(gòu)的包劃分方式。
而微服務(wù)架構(gòu),則是從整體去看,整合多個(gè)單體應(yīng)用,它們之間通過應(yīng)用SDK工程進(jìn)行RPC通訊。
這個(gè)工程比較好理解,類似于我們傳統(tǒng)的理解的RPC包,或者叫API包,在Maven工程里,一般定義為一個(gè)子Module,里面主要定義的是Feign接口(如service.XxxFeignService),DTO對(duì)象(contract.dto.XxxRequest/XxxResponse)等等,此外還可以對(duì)FeignService返回的數(shù)據(jù)進(jìn)行清洗與簡單通用的封裝(如util.XxxUtil),也就是說它還能封裝簡單的業(yè)務(wù)邏輯。
但需要特別注意:應(yīng)用SDK要往一個(gè)大尺度獨(dú)立的聚合工程的方向去搭建,它里面的頂層包要按內(nèi)部業(yè)務(wù)系統(tǒng)的維度去隔離,并且它和業(yè)務(wù)系統(tǒng)不是一對(duì)一的關(guān)系。
為什么要這樣設(shè)計(jì)?我講個(gè)例子你就明白了。
我們公司的業(yè)務(wù)系統(tǒng)在頂層劃分為SaaS應(yīng)用和PaaS應(yīng)用,那么PaaS應(yīng)用對(duì)應(yīng)的應(yīng)用SDK可以命名為PaaSSdk,在PaaSSdk工程里,包括了消息中心、ChatAI、應(yīng)用市場等PaaS應(yīng)用的外部接口封裝與簡單業(yè)務(wù)邏輯封裝。
這樣做的好處顯而易見——SaaS應(yīng)用需要用到PaaS應(yīng)用的接口時(shí),只需要引入PaaSSdk即可,原則上這個(gè)內(nèi)部Sdk與我們平時(shí)引入的外部Jar包沒什么區(qū)別,可能只是網(wǎng)關(guān)和鑒權(quán)體系不一樣罷了。
而且,簡單的業(yè)務(wù)系統(tǒng)就用一個(gè)module就好了,沒必要再拆分多個(gè)module,要知道,每引入多一個(gè)東西就有更多的不確定性。
所以你也就能理解,為什么這里的應(yīng)用Sdk與業(yè)務(wù)系統(tǒng)不是一對(duì)一的關(guān)系,如果是一對(duì)一,業(yè)務(wù)系統(tǒng)勢必要引入大量的Jar包,這在維護(hù)成本上是個(gè)災(zāi)難。試想一下,如果要用到阿里云OSS的Jar包時(shí),你會(huì)引入大量POM嗎?
DDD建模與落地的這幾年,收獲了不少好評(píng),也著實(shí)為業(yè)務(wù)成功做出了貢獻(xiàn),優(yōu)化了大半年,如今終于可以跟大家正式見面了。
先談架構(gòu)思想:
DDD四層架構(gòu)說明:
領(lǐng)導(dǎo)讓你搭個(gè)業(yè)務(wù)系統(tǒng),如果什么都從零開始的話,項(xiàng)目周期就太長了。我們在搭建系統(tǒng)的過程中,如果有這么一個(gè)框架,能夠快速解決CRUD、工程結(jié)構(gòu)劃分等等問題就好了。
D3boot基礎(chǔ)框架的出現(xiàn),正是為了解決這個(gè)問題。一般SpringBoot只能集成Spring體系內(nèi)的技術(shù)棧,但作為心態(tài)更開放的我們,不應(yīng)把目光聚焦在Spring體系內(nèi),每家企業(yè)都應(yīng)該有自己的基礎(chǔ)框架。
D3boot,意為DDD工程快速啟動(dòng),其中融入了DDD領(lǐng)域驅(qū)動(dòng)的架構(gòu)思想,并且能處處體現(xiàn)充血模型帶來的CRUD上的便利,還支持SaaS應(yīng)用的搭建(租戶隔離)。D3boot框架旨在快速搭建SaaS業(yè)務(wù)系統(tǒng),減少繁瑣的CRUD定義,減少不必要的xml代碼書寫。
充血模型的思想體現(xiàn)在對(duì)Model的繼承,即可實(shí)現(xiàn)你想要的CRUD;而通過領(lǐng)域工廠(Factory的build、convert、fill等方式),又可以利用貧血模型思想的優(yōu)勢,對(duì)復(fù)雜的對(duì)象進(jìn)行構(gòu)建、轉(zhuǎn)換、填充,彌補(bǔ)了充血模型的不足。
目前我已使用這套輕量級(jí)微服務(wù)基礎(chǔ)框架,在公司里的健康管理平臺(tái)、消息中臺(tái)、工單中臺(tái)、社交中臺(tái)、ChatAI等業(yè)務(wù)系統(tǒng)應(yīng)用了起來,使用感受一個(gè)字:舒服。
而作為基礎(chǔ)框架,考慮的更多是不同框架集成的問題、功能邊界問題,接下來我給大家一一介紹。
以下是D3boot的結(jié)構(gòu):
可擴(kuò)展的基礎(chǔ)組件,下面包括多個(gè)子模塊,包括:
定義了基礎(chǔ)核心上下文(如SpringContext、ThreadContext、BaseContext)、核心契約(如R對(duì)象、Page對(duì)象、抽象領(lǐng)域事件、業(yè)務(wù)異常、統(tǒng)一狀態(tài)碼等)、核心工具類(如Bean轉(zhuǎn)換工具、Json轉(zhuǎn)換工具、業(yè)務(wù)斷言工具等)。
定義了基礎(chǔ)模型(支持CRUD的充血模型)、基礎(chǔ)倉庫及MybatisPlus的倉庫實(shí)現(xiàn)、數(shù)據(jù)類型處理器等,支持通過@TenantId注解PO類租戶字段來隔離租戶數(shù)據(jù)等。用到數(shù)據(jù)庫的工程需要依賴此包。
目前集成了Kafka消息隊(duì)列,可快速通過注解方式實(shí)現(xiàn)MQ消費(fèi)。
工具類,底下按不同的能力又細(xì)分為緩存類、事件類、語言類、線程類、WEB類工具。
集成HealthCheck接口、啟動(dòng)打印代碼版本功能、日志告警功能(能把log.error的日志告警到企微機(jī)器人/釘釘機(jī)器人)。
定義了CRUD控制器基類CRUDController、按端劃分的模型控制器接口ModelController、全局異常增強(qiáng)、全局R對(duì)象包裝、全局Feign異常降級(jí)、各類WEB攔截器、基礎(chǔ)接口認(rèn)證功能等。WEB工程需要依賴此包。
Maven的BOM(Bill of Materials)機(jī)制是Maven項(xiàng)目中的一個(gè)重要概念,它用于管理項(xiàng)目的依賴關(guān)系和版本控制。BOM機(jī)制可以幫助開發(fā)人員快速構(gòu)建和維護(hù)項(xiàng)目,并且可以確保項(xiàng)目的穩(wěn)定性和可靠性。
Spring有自己的bom文件,如spring-boot-dependencies,里面定義了構(gòu)建SpringBoot工程所需要的依賴。
參考Spring的方式,我們把第三方的依賴統(tǒng)一在base-bom組件里進(jìn)行管理,這樣一來,業(yè)務(wù)工程只需要引入對(duì)應(yīng)的dependency即可(包括定義D3boot框架里的組件版本),不需要再在業(yè)務(wù)系統(tǒng)過多地指定用哪個(gè)版本,達(dá)到版本統(tǒng)一的效果。
作為應(yīng)用SDK工程的父POM,快速搭建應(yīng)用SDK。
作為業(yè)務(wù)工程的父POM,快速搭建業(yè)務(wù)系統(tǒng)。
基于D3boot框架搭建的DDD四層架構(gòu)風(fēng)格的業(yè)務(wù)工程,寫得比較粗糙,具體參考架構(gòu)圖的實(shí)現(xiàn)為準(zhǔn)。

我們在微信上24小時(shí)期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流