主頁 > 資料庫 > 小團隊也能做DDD-上篇

小團隊也能做DDD-上篇

2020-11-16 00:42:09 資料庫

作者簡介:胡正軍,御家匯架構團隊負責人,坐標湖南長沙,開發,運維,測驗,大資料均有負責,雜而不精,樂于復雜系統重構,擁抱DDD

上一篇文章說了小團隊也能做中臺,里面提到我們用了領域驅動設計(DDD)這個方法論來開發中臺,本文對我們為什么使用DDD做一個分享,下一篇再講我們怎么實踐的DDD,

DDD出現得很早,2004年Eric Evans就寫了《領域驅動設計:軟體核心復雜性應對之道》,但使用并不廣泛,拿長沙這邊來說,使用的企業可以說是寥寥無幾,

最近幾年DDD隨著微服務反而火了一把,各種技術群里一言不合就DDD,也有一些在線培訓和書籍出版,比如人保的架構師歐創新就在極客時間開了專欄,預計本月還會出版一本書籍,然而大家雖然談論得多,真正落地的少,

我認為原因有:

< 1 >系統不復雜,沒必要用DDD;

< 2 > DDD概念多,理解難,懶得去學;

< 3 > 就算一個人學了也沒用,需要團隊都用起來,由于人性本懶惰,DDD對業務和開發都要求有點高,所以不想做,還是CRUD爽點,


DDD是為了解決復雜業務系統構建的一套方法論,有戰略設計和戰術設計兩大塊,

戰略設計的核心是統一語言和限界背景關系,戰術設計的核心是獨立領域邏輯層,

復雜業務系統為什么要用DDD,可以從3個維度來說明,

這3個維度分別是軟體開發程序復雜系統設計模塊編碼

可以看到這3個維度是一級一級降低維度的,軟體開發程序涉及多個崗位(產品經理,開發,測驗,業務運維),屬于開發流程這個維度,復雜系統設計涉及的崗位是架構師或者高級開發,屬于架構設計這個維度,模塊編碼涉及的崗位主要是開發了,屬于代碼撰寫這個維度,我們先分析這3個維度上有什么問題,再看DDD都能提供什么指導,

一、軟體開發程序

一個簡單系統的開發是不需要分這么多崗位的,大學期間做的一些兼職小專案就是一個人把需求,開發,測驗,運維全做了,效率很高,如果說搞多個崗位多個人來做,反而效率很低,

不過這種情況隨著專案復雜度上升就不一樣了,一個人是沒法搞定所有事情的,于是我們設立了各種崗位,通過團隊分工讓專業的人做專業的事情,

拿開發這個崗位來說還分了前端和后臺開發,也是因為技術復雜性的要求,必須分工,一個理論是建立知識壁壘并能有效交換能提高效率,這個方面詳細的論述可以看下八叉說的視頻,通過專業分工來提升效率在生活中有很多地方都有體現,比如流水線作業什么的,這在國富論和科學管理中也有提到,這個方面詳細的論述可以看下八叉說的視頻,

這里得到第一個結論:

軟體開發程序中的技術知識通過分工建立知識壁壘來提升效率

但是軟體開發還有一類知識是沒法通過分工解決了,上圖箭頭表示的就是領域知識必須隨崗位傳遞,需求分析師把業務轉換成需求檔案,然后這個需求檔案里面的業務知識必須傳遞給開發,開發必須理解清楚了才能干活,現實中確實出現了很多這樣的情況,開發需求都沒理解透,就開始設計編碼,最后做出的東西跟實際業務需求不一樣,返工,開發和產品經理矛盾重重,如何讓業務知識快速傳遞,是迫切需要解決的問題,

這里得到第二個結論:

軟體開發程序中的業務知識需要消除知識壁壘才能提升效率

從兩個結論看好像有沖突,從第一個結論看,分工是有意義的,從第二結論看,不分工反而是好的,隨著各個崗位專業度的提高,分工是必然的,那么怎么解決業務知識傳遞問題, DDD的一個核心模式是統一語言,用于解決解決業務知識傳遞的問題,

統一語言有兩個含義,

1、統一交流語言,我們把業務名詞的含義事先確定好,在業務和技術的各個崗位都統一認知,這樣在交流時,由于對業務名詞的理解已經同頻了,會節省很多溝通成本,

這里舉個沒統一語言的例子,我們公司有個有個渠道的概念,每次討論這個渠道就容易出現每個人理解不一樣,有的把電商平臺一個店鋪當渠道,有的把電商平臺當渠道,還有人理解成其他含義,這是因為每個公司都有些歷史遺留原因對名詞的定義變味道了,

2、統一領域模型和代碼模型,我們知道一個系統最重要的知識沉淀就是代碼和檔案了,當然很多公司都沒檔案,程式員嘛,都一個尿性,恨別人不寫檔案,恨自己寫檔案,想一想當一個新人來接手一個專案,這個專案有一份設計檔案和代碼,設計檔案里面描述的業務模型跟代碼模型不一樣時,我想這個新人是蒙圈的,到底哪個是對的,心里絕對會罵娘,當業務模型和代碼模型一樣,會大大降低我們系統的認知復雜度,

二、 復雜系統設計

為了降低業務系統復雜性,一般是通過分而治之的方式,現在流行的微服務就是基于業務維度進行拆分,那么到底怎么拆分,

如下圖,每個點代表一個領域物件,當很多個物件混合在一起時,設計者或者開發者需要了解所有領域物件,無疑增加了復雜度,如果能找到一種方式合理劃分邊界,讓聯系緊密的物件聚合在一起(比如下圖中形成ABC三個聚合),聚合之間通過介面互動,那么介面數量會是最少的,有點類似K聚類演算法,總能找到一種最優的劃分方法,當然很多情況下依賴架構設計者的經驗,DDD的限界背景關系提供了一種指導思路,限界背景關系劃分好后,一個限界背景關系可以對應一個微服務,

這里同樣運用了建立知識壁壘可以提升效率這個理論,開發A服務的人實際上不需要了解B服務的內部實行,只需要了解B提供的介面即可,A服務的領域物件數量已經大大下降了,無疑降低了復雜度,

拿一個大學里面的一個學生管理系統來說,涉及到如下領域物件:學生,教師,角色,權限,選單,課程,課程排班,簽到等,

現在來劃分限界背景關系,因為學生和教師都需要登錄和權限,我們一種背景關系分解的方法是鑒權背景關系<角色,權限,選單,學生,教師>, 授課背景關系<課程,課程排班,簽到>,

從關聯度來看,這兩個背景關系需要4個介面來做互動,

由于DDD里面規定限界背景關系一個領域物件有確定的含義,學生和教師這個兩個在鑒權背景關系里面是系統的一個用戶,放到授課背景關系里面代表了兩種不同的身份,也就是當我們說到學生時,到底是需要登錄的一個用戶還是授課里面的學生,含義是不確定的,所以這里缺了一個領域物件用戶,

增加用戶這個領域物件后,限界背景關系重新劃分,只需要2個介面做互動,

三、模塊編碼

傳統的三層結構是web,service,dao,這個大伙都很熟悉,一個業務流程稍微復雜點會導致service里面的代碼變成大泥球,我在上一份作業中,見過一個service類達到上萬行,維護及其痛苦,怎么痛苦法呢,就是每次轉測驗,都會產生20多個bug,改完又會出現新的,一輪一輪無法收斂,我實在受不了,就跟專案經理申請重構,專案經理是不同意的,沒辦法只能立軍令狀,就開干了,最終一萬多行代碼變成4000行左右,bug終于收斂,

解決service層大泥球的一個方法是分離復雜性,把service分為應用層和領域層,這塊內容可以參考王林在infoq的文章

(https://www.infoq.cn/article/A3cgSUWuRulXHl2c_dUr),文章中提到了一個架構原則是業務和技術分離,領域層放業務邏輯,應用層放技術邏輯,復雜性降低,并且領域層更便于測驗,


DDD戰術設計就是把業務邏輯放到最核心位置,整潔架構和六邊形架構也是如此,跟業務相關的代碼寫到物體,值物件和領域服務里面,一些事務,快取等技術相關代碼寫到應用服務里面,

舉例說明:購物車有個操作是添加商品到購物車,應用層ShoppingCartApplicationService把事務,快取處理掉,核心業務邏輯在ShoppingCart這個領域物件里面,

領域層代碼如下:

應用層代碼如下:

四、總結

DDD的統一語言在軟體開發程序中能幫助業務知識更好的傳遞,限界背景關系能指導復雜系統的拆分,戰術設計能幫助代碼更好的分層,

有的公司雖然沒有用DDD這么一套組合拳,可能已經在利用這些好的方法來開發軟體,其實DDD提供一套方法論,也不是必須全部用上,完全可以只借鑒其中一部分,比如DDD的統一語言是通過降低業務知識的傳遞提升效率,可以應用到實際開發中,

舉一個實際的例子,很多企業內部系統也采用了前后端分離,然后用前端開發和后臺開發兩撥人分別開發,再介面聯調,聯調成本很大,完全可以換一種方式,讓后臺開發來做前端,節省聯調成本,

那這里可能有人有疑問,后臺開發做前端會不會效率很低?其實只要讓前端提供了架子和前端組件,再輔助一些組件使用檔案和代碼示例,后臺開發完全可以很快上手,而節省的聯調成本會很可觀,

最后想說一句,方法論能提供指導,但也不要生搬硬套,需要根據自身情況進行裁剪,靈活運用,

—————————— END ——————————

往期推薦

  • 2.5 億!華為突然成立新公司

  • 小團隊也能做中臺(作者原創)

  • 認知升級:從首席架構師到CTO

  • 應該這么設計億級用戶秒殺系統!

  • CTO喬新亮:從死戰沖鋒陷陣的猛將,到掌兵多多益善的元帥

技術瑣話

以分布式設計、架構、體系思想為基礎,兼論研發相關的點點滴滴,不限于代碼、質量體系和研發管理,本號由坐館老司機技術團隊維護,

長按掃碼關注



【您的在看,我的莫大鼓勵】

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/218741.html

標籤:其他

上一篇:使用Kafka訂閱資料庫的實時Binlog

下一篇:面試 | 多執行緒中的背景關系切換

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more