注冊(cè) | 登錄讀書好,好讀書,讀好書!
讀書網(wǎng)-DuShu.com
當(dāng)前位置: 首頁出版圖書科學(xué)技術(shù)計(jì)算機(jī)/網(wǎng)絡(luò)軟件工程及軟件方法學(xué)DDD工程實(shí)戰(zhàn):從零構(gòu)建企業(yè)級(jí)DDD應(yīng)用

DDD工程實(shí)戰(zhàn):從零構(gòu)建企業(yè)級(jí)DDD應(yīng)用

DDD工程實(shí)戰(zhàn):從零構(gòu)建企業(yè)級(jí)DDD應(yīng)用

定 價(jià):¥99.00

作 者: 鄭天民 著
出版社: 機(jī)械工業(yè)出版社
叢編項(xiàng):
標(biāo) 簽: 暫缺

ISBN: 9787111717874 出版時(shí)間: 2023-02-01 包裝: 平裝-膠訂
開本: 16開 頁數(shù): 字?jǐn)?shù):  

內(nèi)容簡(jiǎn)介

  這是一本能教你快速從零構(gòu)建一個(gè)完整的企業(yè)級(jí)DDD應(yīng)用的實(shí)戰(zhàn)性著作。DDD本身涉及的概念多,而且技術(shù)組件的實(shí)現(xiàn)也比較復(fù)雜,對(duì)于初學(xué)者來說門檻相對(duì)較高。本書在寫作上另辟蹊徑,首先用很短的篇幅將限界上下文、聚合、實(shí)體等十幾組核心概念和技術(shù)組件,以及Spring Boot、Spring Cloud和Axon等開發(fā)DDD應(yīng)用的主流開源框架做了一個(gè)簡(jiǎn)單的介紹,然后用8章的篇幅講解了一個(gè)綜合性的案例,不僅將前面提到的這些核心概念、技術(shù)組件和開發(fā)框架的原理、使用全部融入到了案例中,還一步步地詳細(xì)講解了DDD應(yīng)用的實(shí)現(xiàn)方式和落地細(xì)節(jié)。通過閱讀本書,你能獲得以下收獲:架構(gòu)設(shè)計(jì):基于DDD核心概念設(shè)計(jì)業(yè)務(wù)體系架構(gòu)。技術(shù)體系:根據(jù)DDD技術(shù)實(shí)現(xiàn)模型掌握主流框架的應(yīng)用。案例實(shí)戰(zhàn):遞進(jìn)式演練DDD核心理念及技術(shù)的落地實(shí)現(xiàn)。工程實(shí)施:提升DDD工程的整體實(shí)施水平和能力。

作者簡(jiǎn)介

  鄭天民資深架構(gòu)師和技術(shù)專家,有近15年的軟件研發(fā)和架構(gòu)經(jīng)驗(yàn)。現(xiàn)擔(dān)任某知名健康科技公司技術(shù)總監(jiān),先后就職于多家大型上市公司和互聯(lián)網(wǎng)獨(dú)角獸公司,擔(dān)任系統(tǒng)架構(gòu)師、技術(shù)總監(jiān)和CTO等職務(wù)。對(duì)架構(gòu)設(shè)計(jì)和技術(shù)管理有深入的理解,積累了豐富的經(jīng)驗(yàn),研發(fā)和主持過10余個(gè)面向研發(fā)人員的技術(shù)和管理類培訓(xùn)課程。熱衷于總結(jié)和分享,著有《分布式系統(tǒng)架構(gòu)與開發(fā):技術(shù)原理與面試題解析》《Spring Boot進(jìn)階:原理、實(shí)戰(zhàn)與面試題分析》等著作。 阿里云MVP、騰訊云TVP、TGO鯤鵬會(huì)會(huì)員。

圖書目錄

前 言
第1章 引入DDD 1
1.1 面向領(lǐng)域的設(shè)計(jì)思想 1
1.1.1 業(yè)務(wù)模型和系統(tǒng)復(fù)雜度 2
1.1.2 領(lǐng)域驅(qū)動(dòng)設(shè)計(jì)的維度 4
1.2 面向領(lǐng)域的設(shè)計(jì)方法 4
1.2.1 面向領(lǐng)域的戰(zhàn)略設(shè)計(jì) 5
1.2.2 面向領(lǐng)域的戰(zhàn)術(shù)設(shè)計(jì) 7
1.3 應(yīng)用DDD 12
1.3.1 DDD與單體架構(gòu) 12
1.3.2 DDD與微服務(wù)架構(gòu) 13
1.3.3 DDD與中臺(tái)架構(gòu) 14
1.4 本章小結(jié) 15
第2章 DDD核心概念 16
2.1 子域和限界上下文 16
2.1.1 子域的類型 17
2.1.2 限界上下文的映射和集成 17
2.2 領(lǐng)域模型對(duì)象 20
2.2.1 實(shí)體和值對(duì)象 20
2.2.2 聚合 25
2.3 領(lǐng)域服務(wù) 28
2.4 領(lǐng)域事件 29
2.5 資源庫 31
2.5.1 資源庫模式 31
2.5.2 資源庫的設(shè)計(jì)策略 32
2.6 應(yīng)用服務(wù) 33
2.6.1 應(yīng)用服務(wù)的定位 33
2.6.2 應(yīng)用服務(wù)的分類 34
2.7 基礎(chǔ)設(shè)施 34
2.8 本章小結(jié) 35
第3章 DDD案例分析 37
3.1 HealthMonitor業(yè)務(wù)體系 37
3.1.1 案例描述和通用語言 37
3.1.2 案例建模流程 39
3.2 子域和限界上下文 40
3.2.1 HealthMonitor子域 40
3.2.2 HealthMonitor限界上下文 42
3.3 領(lǐng)域模型對(duì)象 44
3.3.1 HealthMonitor聚合 44
3.3.2 HealthMonitor實(shí)體 45
3.3.3 HealthMonitor值對(duì)象 46
3.4 領(lǐng)域事件和事務(wù) 47
3.4.1 HealthMonitor領(lǐng)域事件 48
3.4.2 HealthMonitor事務(wù) 50
3.5 應(yīng)用服務(wù) 50
3.5.1 HealthMonitor命令服務(wù) 51
3.5.2 HealthMonitor查詢服務(wù) 53
3.6 限界上下文集成 54
3.7 本章小結(jié) 55
第4章 DDD實(shí)現(xiàn)技術(shù) 56
4.1 DDD技術(shù)實(shí)現(xiàn)模型 57
4.1.1 單體模型 57
4.1.2 系統(tǒng)集成模型 58
4.1.3 微服務(wù)模型 59
4.1.4 消息通信模型 60
4.2 Spring Boot與DDD實(shí)現(xiàn)模型 61
4.2.1 Spring Boot 62
4.2.2 Spring Data 64
4.3 Spring Cloud與DDD實(shí)現(xiàn)模型 65
4.3.1 Spring Cloud基礎(chǔ)組件 65
4.3.2 Spring Cloud Stream 67
4.4 Axon與DDD實(shí)現(xiàn)模型 68
4.4.1 CQRS和事件溯源 68
4.4.2 Axon框架 70
4.5 本章小結(jié) 71
第5章 案例實(shí)現(xiàn):限界上下文 72
5.1 Spring Boot應(yīng)用程序 72
5.1.1 傳統(tǒng)Spring Boot應(yīng)用程序 73
5.1.2 基于DDD的Spring Boot
應(yīng)用程序 76
5.2 創(chuàng)建第一個(gè)限界上下文 78
5.2.1 代碼包結(jié)構(gòu) 78
5.2.2 領(lǐng)域?qū)ο蟆?9
5.2.3 應(yīng)用服務(wù) 80
5.2.4 基礎(chǔ)設(shè)施 81
5.2.5 接口 81
5.2.6 集成 82
5.3 實(shí)現(xiàn)HealthMonitor限界上下文 84
5.3.1 代碼工程 84
5.3.2 限界上下文映射 85
5.4 本章小結(jié) 86
第6章 案例實(shí)現(xiàn):領(lǐng)域模型對(duì)象 87
6.1 創(chuàng)建聚合 88
6.2 抽取實(shí)體和值對(duì)象 89
6.2.1 抽取實(shí)體 89
6.2.2 抽取值對(duì)象 92
6.3 為聚合添加領(lǐng)域邏輯 94
6.3.1 實(shí)現(xiàn)申請(qǐng)健康監(jiān)控領(lǐng)域邏輯 95
6.3.2 實(shí)現(xiàn)創(chuàng)建健康計(jì)劃領(lǐng)域邏輯 97
6.3.3 實(shí)現(xiàn)執(zhí)行健康任務(wù)領(lǐng)域邏輯 97
6.4 實(shí)現(xiàn)HealthMonitor領(lǐng)域模型對(duì)象 99
6.4.1 HealthPlan聚合 99
6.4.2 HealthTask聚合 99
6.4.3 HealthRecord聚合 100
6.4.4 共享領(lǐng)域?qū)ο蟆?00
6.5 本章小結(jié) 101
第7章 案例實(shí)現(xiàn):應(yīng)用服務(wù) 102
7.1 應(yīng)用服務(wù)實(shí)現(xiàn)策略 102
7.2 實(shí)現(xiàn)應(yīng)用服務(wù) 105
7.2.1 實(shí)現(xiàn)命令服務(wù) 105
7.2.2 實(shí)現(xiàn)查詢服務(wù) 108
7.3 整合應(yīng)用服務(wù)和聚合 110
7.4 實(shí)現(xiàn)HealthMonitor應(yīng)用服務(wù) 111
7.5 本章小結(jié) 113
第8章 案例實(shí)現(xiàn):資源庫 114
8.1 資源庫實(shí)現(xiàn)策略 114
8.2 Spring Data JPA 116
8.2.1 Spring Data抽象 116
8.2.2 JPA規(guī)范 117
8.2.3 多樣化查詢 118
8.3 實(shí)現(xiàn)資源庫 122
8.3.1 創(chuàng)建PO和工廠 122
8.3.2 創(chuàng)建Mapper 124
8.3.3 實(shí)現(xiàn)Repository 126
8.4 整合資源庫和應(yīng)用服務(wù) 128
8.5 實(shí)現(xiàn)HealthMonitor資源庫 129
8.6 本章小結(jié) 131
第9章 案例實(shí)現(xiàn):領(lǐng)域事件 132
9.1 領(lǐng)域事件實(shí)現(xiàn)策略 132
9.2 基于Spring Data生成領(lǐng)域事件 134
9.2.1 @DomainEvents注解和
AbstractAggregateRoot 135
9.2.2 @TransactionalEventListener
注解 136
9.3 基于Spring Cloud Stream發(fā)布和
訂閱領(lǐng)域事件 137
9.3.1 Spring Cloud Stream整體
架構(gòu) 137
9.3.2 實(shí)現(xiàn)Spring Cloud Stream
Source 142
9.3.3 實(shí)現(xiàn)Spring Cloud Stream
Sink 146
9.4 實(shí)現(xiàn)HealthMonitor領(lǐng)域事件 152
9.5 本章小結(jié) 152
第10章 案例實(shí)現(xiàn):限界上下文集成 153
10.1 限界上下文集成策略 153
10.1.1 統(tǒng)一協(xié)議和防腐層 154
10.1.2 服務(wù)注冊(cè)和發(fā)現(xiàn) 155
10.2 基于REST API構(gòu)建統(tǒng)一協(xié)議 156
10.2.1 創(chuàng)建Controller 156
10.2.2 處理Web請(qǐng)求 157
10.2.3 集成應(yīng)用服務(wù) 158
10.3 基于REST API構(gòu)建防腐層 162
10.3.1 創(chuàng)建和使用RestTemplate 162
10.3.2 創(chuàng)建防腐層組件 165
10.3.3 集成命令服務(wù) 166
10.4 本章小結(jié) 168
第11章 案例實(shí)現(xiàn):事件溯源和CQRS 169
11.1 事件溯源和CQRS的實(shí)現(xiàn)策略 169
11.1.1 事件溯源模式的設(shè)計(jì)理念 170
11.1.2 整合事件溯源和CQRS 171
11.2 Axon框架 172
11.2.1

本目錄推薦

掃描二維碼
Copyright ? 讀書網(wǎng) ranfinancial.com 2005-2020, All Rights Reserved.
鄂ICP備15019699號(hào) 鄂公網(wǎng)安備 42010302001612號(hào)