軟體設計、DDD概念及落地時的一些零碎思考和記錄

来源:https://www.cnblogs.com/cerl/archive/2018/11/14/9951846.html
-Advertisement-
Play Games

DDD理解 DDD體現的是對現實的充分尊重。 1.尊重業務現實,領域專家、領域語言等概念 2.尊重團隊現實 3.尊重變化 Application 對某一業務線的整體掌控,流程組裝,進度管理,存儲時機掌控。 依賴外部模塊的業務環節實現; 儘量滿足UI需求; 落地:uow提交; Domain 業務線視作 ...


DDD理解

DDD體現的是對現實的充分尊重。
1.尊重業務現實,領域專家、領域語言等概念
2.尊重團隊現實
3.尊重變化

Application

  • 對某一業務線的整體掌控,流程組裝,進度管理,存儲時機掌控。
  • 依賴外部模塊的業務環節實現;
  • 儘量滿足UI需求;
  • 落地:uow提交;

Domain

  • 業務線視作水平線的話,此處應在垂直方向上切分各業務線,重新整合抽象,處理具體的業務環節、業務步驟。
  • 劃分範圍、確定職責,需要多維度多視角的考慮抽象;
  • 粒度儘量小。
  • 本質上是對業務邏輯處理過程的純化,能用的技術手段實質上是受限的;
  • 不要考慮業務邏輯跨項目跨產品的通用性,這是以後的事;
  • 緩存和倉儲需要註意,有必要的話分開;
  • 落地:儘量少的執行 存儲,最好沒有;
    在記憶體中處理邏輯;
    儘量使用private set;
    儘量避免鎖與線程操作;
    註意時間、時刻及引用的問題;

存儲、查詢

  • 存儲的重要性僅次於Domain。
  • 存儲的隔離有兩種,一種僅隔離不同的資料庫,一種連ORM也隔離開;
  • 大多數情況下不需要隔離ORM,技術選型確定後,使用時不必有過多顧慮;
  • 如果使用EFCore這種ORM,DbSet和DbContext可以進入Domain;
  • 查詢與存儲關聯非常緊密同時距離用戶很近(兩個地獄),技術手段可以放寬,存儲過程、Db函數,lua腳本之類都可以考慮;
  • Domain可以對查詢進行一些適配,或優化(後期);
  • 快照時機,快照性能;
  • 實時、非實時查詢;
  • 複雜報表需要自行適配業務數據;

命令、事件、消息。。。

  • 匯流排隊列比較容易被接受;
  • 事件可以分階段落地;
  • 就算是日誌也要養成記錄快照的習慣;

標識

  • 避免自增Id;
  • 分散式id,大部分時候可以使用CombineGuid(唯一、基本有序、隨機、提前生成);
  • 進行事件快照時可以使用同一id,不同事件類型進行處理。
  • 通常會發生變化的對象需要一個標識。

實體與值對象

  • 實體屬性會產生變化用於描述記錄業務生命期內的各種事件,實體本身及引用的實體都會變化,實體間的關係通常使用引用來表達;
  • 值對象本身是偏概念的東西,用過函數語言的會比較容易理解,在c#中與之類似的有元組、匿名類和提案里的record;
  • 這裡最重要的是思想的引入而非手段。
  • 值對象本身表達的是部分屬性的快照副本,類似於實體擁有的所有屬性上的一段切片,是某個時刻下的一小段副本,所以不需要標識也只能是只讀的;
  • 屬於使用者/調用者關註的東西,如果沒有人關註它,通常沒有必要單純為表達某個概念而增加,容易造成概念混亂;
  • 實體的變化會使邏輯處理產生隱患,尤其是涉及到引用類型時,這時引入值對象的快照副本概念就會很自然,比如使用一些變數取出屬性值,或者一個匿名類用於方法內部,或者在方法的參數上僅提供類型的參數,總之“邏輯演算法僅能處理當前時刻的對象狀態” 這一層概念必須明確表達。
  • 實體的邏輯處理通常會導致實體自身屬性的變化,業務上對實體屬性的變化通常很敏感,有時不能僅提供一個結果給需求方,這時我們就需要增加一些屬性記錄下結果產生的原因。
  • 值對象不在於我們定義的類型結構,而是要幫助技術人員建立起值的概念,快照副本及當前時刻是關鍵點,這種概念的建立非常有助於理解業務事件;
    ------------------------------------------------------------------上面是值對象值的部分,下麵是對象部分(結構,屬性包);
  • 有時候我們的邏輯中會有“我不關心是什麼類型的實體,我只關心是否符合某種結構(屬性包,形狀)”,也就是實體在不同視角下的形狀,關註點產生了變化。
  • 一般在一些橫切式的模塊或者分析類的模塊中有應用。
  • 字典、配置類使用實體,更新原狀態,插入新記錄。

後臺

  • 系統後臺:監控,分散式管理。。。;

  • 管理後臺不可直接引用Domain自行組裝業務流(使用介面);
  • 管理後臺的需求必須與業務線需求一同交給Domain處理;
  • 手工操作功能沒有小事;

    安全許可權

    貫穿始終;

團隊

  • 溝通、信任 “敬汝代碼而惕之”,

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 什麼時候不能使用箭頭函數? 1、定義對象方法 JS中對象方法的定義方式是在對象上定義一個指向函數的屬性,當方法被調用的時候,方法內的this就會指向方法所屬的對象。 1.1定義字面量方法 因為運行的時候this.array未定義,調用calculator.sum時,執行上下文里的this仍指向的是w ...
  • CSS 在前面大概的介紹了css,從本片博文開始,會詳細的介紹它 1.什麼是css樣式 2.css樣式的作用 3.css樣式 ...
  • 一、區別:簡單點來說,就是假設B複製了A,當修改A時,看B是否會發生變化,如果B也跟著變了,說明這是淺拷貝,如果B沒變,那就是深拷貝。 此篇文章中也會簡單闡述到棧堆,基本數據類型與引用數據類型,因為這些概念能更好的讓你理解深拷貝與淺拷貝。 例如: 二·、從基本類型和引用的數據存儲上面區別理解: a. ...
  • 1、在項目裡面使用了axios.js來發送http請求,在IE下報錯Promise未定義,解決辦法: 到http://bluebirdjs.com/docs/getting-started.html 下載 bluebird.min.js腳本加入頁面,解決Promise未定義的錯誤 2、IE11不支持 ...
  • ...
  • 一、瞭解 基本數據類型保存在棧記憶體中,按值訪問,引用數據類型保存在堆記憶體中,按址訪問。 二、淺拷貝 淺拷貝只是複製了指向某個對象的指針,而不是複製對象本身,新舊對象其實是同一記憶體地址的數據,修改其中一個值,另一個也會動態改變。 三、深拷貝 深拷貝是真正意義上實現了數組和對象的拷貝,它創建了另外一個一 ...
  • web前端怎麼樣才能入門,首先我們要從什麼是初級web前端工程師說起: 按照我的想法,我把前端工程師分為了入門、初級、中級、高級這四個級別, 入門級別指的是瞭解什麼是前端(前端到底是什麼其實很多人還是不清楚的),瞭解基本的html、css和javascript語法(這些語方面的東西網上隨便搜一下就有 ...
  • element vue Array數組和Map對象的添加與刪除 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...