猜你喜欢
复杂软件设计之道:领域驱动设计全面解析与实战

复杂软件设计之道:领域驱动设计全面解析与实战

书籍作者:彭晨阳 ISBN:9787111661122
书籍语言:简体中文 连载状态:全集
电子书格式:pdf,txt,epub,mobi,azw3 下载次数:1347
创建日期:2021-02-14 发布日期:2021-02-14
运行环境:PC/Windows/Linux/Mac/IOS/iPhone/iPad/Kindle/Android/安卓/平板
内容简介
领域驱动设计简称DDD,《复杂软件设计之道:领域驱动设计全面解析与实战》前6章全面解析了DDD的分析方法和技术架构,包括领域驱动设计基础、领域驱动战略设计(有界上下文和统一语言)、聚合设计、实体和值对象、CQRS架构和事件溯源,第7章使用经典的货物运输系统案例进行了完整、详细的综合演示。
《复杂软件设计之道:领域驱动设计全面解析与实战》同时引入了DDD的*新发展成果,如事件风暴建模,并以此建模方式替代传统的DDD建模方式讲解了多个案例。还涉及大量软件系统实现相关的技术和架构,读者在学习DDD的同时,也可以掌握这些技术、架构在DDD实现中的灵活应用。
另外,每个概念或方法的讲解过程都穿插了具体实例,以方便读者结合实例进行学习;第2~7章每章*后都有总结与拓展,将本章涉及的案例和知识进行总结,并引入国际DDD专家的心得经验,试图告诉读者一条DDD实战中行之有效的途径。
《复杂软件设计之道:领域驱动设计全面解析与实战》主要面向拥有一定实践经验的软件产品经理、领域专家、软件设计开发相关从业人员,相关初级从业者也可阅读本书。
作者简介
作者彭晨阳,常用网名板桥(bang),DDD等软件架构专研网站——解道(Jdon)的创办者,长期关注国内外软件架构思想和设计开发的新动向,自DDD提出以来,持续研究与实践DDD。
行业经验——具有近30年的软件系统设计与开发经验,以及丰富的领域实战经验,包括ERP、电子商务、政务、电力、银行、大型游戏等。
培训经历——致力于传播软件设计开发新思想、新技术,曾为近百家企业提供培训咨询服务,包括华为、阿里等企业。
擅长方向——系统架构设计与实现,设计模式与框架,并发编程和微服务、区块链等分布式系统与事务。擅长复杂系统的软件架构和领域建模。
编辑推荐
适读人群 :主要面向拥有一定实践经验的软件产品经理、领域专家、软件设计开发相关从业人员,相关初级从业者也可阅读本书。
为读者提供更加清晰的DDD知识脉络,各个击破、详细解析;
讲解过程伴随实例代码,让读者的学习过程更加轻松;
包含原著以外的DDD社区新发展,基于截至2020年初的全新、全面DDD思想/方法体系编写;
推荐作为原著学习伴侣,在实践中反复学习与思考。
前言
“领域驱动设计”一词源于Eric Evans在2004年出版的图书《Domain-Driven Design: Tackling Complexity in the Heart of Software》,而Eric Evans也因此被称为“领域驱动设计之父”。领域驱动设计简称DDD,它是面向对象、设计模式、函数式编程的集大成者,是软件设计发展的主要方向之一。DDD诞生十多年来一直处于高速发展中,其超前思想正在指引着企业软件技术的发展,清洁(Clean)架构、六边形架构、CQRS架构、事件溯源架构、微服务架构、无服务器架构等都与DDD有着紧密联系,DDD更是微服务架构实现的基础知识。
DDD是一种平衡业务和技术设计的方法学。通常,我们把产品经理或领域专家称为业务人员,把程序员称为技术人员,一套高质量的软件产品或项目需要两者合作才能完成,但是由于他们各自的领域背景不同,所以难以沟通和合作,而DDD则提供了一套业务建模与实现方法来消除两者间的隔阂。
为什么写这本书
写这本书的原因有二。
DDD中引入了上下文、聚合等难以理解或实践的概念,导致新手入门和使用比较难,而笔者自DDD出现以来,一直专注于其中,并在以jdon为主的分享平台上不断记录自己的使用心得和国外DDD的最新发展情况,所以编写此书,并且以国内软件设计人员更易理解的结构和语言对Eric Evans所著书中的抽象概念、建模方法进行了梳理和全面解析,以此作为多年沉淀的总结。这是原因之一。
自DDD出现以来,随着软件系统的日益复杂,其越发受到软件设计开发相关人员的重视,也得到了新的发展,比如事件溯源、事件风暴会议、失血/贫血模型与充血模型。对DDD中术语的逐步统一和规范,与各种典型技术与架构的结合实现这是笔者编写本书的原因之二,即梳理DDD的现有发展成果,包括与DDD相关的技术与架构。
这本书写给谁
本书主要面向拥有一定实践经验的软件产品经理、领域专家、软件设计开发相关从业人员,产品经理等业务专家可以着重阅读前三个章节。
如果你是一个软件开发新手或还是一个在校学生,也推荐你阅读本书,因为其中的软件设计开发思路与方法定能为你带来极大启发。
如何阅读本书
本书分为7章,首先从DDD的起源、发展、特点等方面出发,呈现了DDD的全貌,然后分别介绍了领域驱动战略设计、聚合设计、实体和值对象、CQRS架构、事件溯源,最后对DDD中经典的货物运输系统案例进行了完整、详细的讲解。
除了各章专门的实例解析外,每个概念或方法的讲解中都穿插了具体实例,读者可以结合实例来理解DDD,学习DDD模型从无到有的分析过程。此外,本书也提供了开放源码实现,还可通过书中的链接进行知识拓展。
本书采用Java语言来具体实现,并涉及大量软件系统实现相关的技术和架构,主要包括数据库、Spring Boot、微服务、分布式事务等,读者在学习DDD建模方法的同时,也可以掌握这些技术、架构在DDD等实现中的灵活应用。
本书主要内容
本书各章内容大致如下。
第 1 章是领域驱动设计基础,介绍了DDD的起源、发展、特点、难点、应用场景,其中对领域复杂性、领域边界、业务策略和业务规则、统一语言和有界上下文等DDD建模方法中的关键概念和过程进行了综述,让读者对DDD建模的总体方向和思路有一个了解。
第 2 章是领域驱动战略设计。领域驱动设计分为战略设计和战术设计两个部分,本章的战略设计从宏观角度进行领域的分析设计,主要讲解了有界上下文、统一语言及多种有界上下文发现方法,也包括对业务平台与中台设计、事件风暴会议的介绍。
第 3 章是聚合设计,属于设计代码阶段,是战术设计部分,它与实体、值对象等对象类型概念共同表达领域模型。本章在介绍聚合设计概念的基础上,又详细讲解了设计聚合的几种方法,包括改变主谓宾顺序、根据领域事件设计聚合、根据单一职责设计聚合、按时间边界设计聚合等,最后以订单系统为例进行了实战解析。
第 4 章是实体和值对象,包括对实体的标识、设计、创建以及值对象与实体的区别、用值对象重构等的描述,并介绍了失血/贫血模型、充血模型、仓储,最后通过一个论坛系统对这些概念和过程进行了详细解析。
第 5 章是CQRS架构,基于对MVC模式、传统三层架构、传统DDD分层架构、清洁架构、六边形架构、垂直分片架构等的介绍与对比,主要讲解了CQRS架构的特点与实现,包括命令与查询分离、数据访问方式、数据同步等内容,最后是一个使用Axon框架实现CQRS架构的案例。
第 6 章是事件溯源,介绍了事件溯源的概念、优点与实现,具体包括基于事件溯源的聚合根设计、微服务中的分布式事务实现、使用Apache Kafka实现事件溯源、投射模式、更改数据捕获等内容。
第 7 章是货物运输系统。Eric Evans的DDD原著中,该案例被拆分到了不同章节,考虑初学者更希望看到完整的分析和实现过程,从而更好地将理论应用于实战,本章从领域描述、发现领域事件、划分有界上下文到聚合设计与代码实现,对货物运输系统的DDD建模过程进行了全面、详细的阐述。
致谢
感谢曾任IBM咨询顾问的陈庆春同行的支持;感谢这些年来为笔者提供DDD项目实践、培训和咨询机会的各大软件企业;感谢机械工业出版社提供出版机会。
最后,DDD的普及与发展
目录
前言

第1章 领域驱动设计基础1
11 领域驱动设计的起源与发展1
111 程序员为难之处1
112 技术负债与软件质量3
113 ER数据建模与面向对象建模4
114 DDD的诞生和发展6
12 领域驱动设计的特点9
121 发现和理解问题10
122 领域即边界13
123 解决复杂性15
124 新的数据结构设计方式17
125 需要注重产品的程序员18
13 领域驱动设计的难点20
131 业务策略和业务规则21
132 统一语言与有界上下文25
133 领域模型的提炼26
14 领域驱动设计的应用场景29
141 哪些应用不适合?30
142 适合微服务架构30
第2章 领域驱动战略设计31
21 有界上下文31
211 统一语言:统一项目中的交流
语言32
212 如何发现有界上下文和统一
语言?34
213 有界上下文之间的关系36
214 核心子域、支持子域与通用
子域37
215 实例解析:电费结算系统38
22 按时间线发现有界上下文40
221 UML时序图40
222 实例解析:电商领域之商品管理
上下文41
23 通过领域故事或流程发现有界
上下文45
24 通过事件风暴会议发现有界
上下文48
241 领域事件50
242 命令51
243 事件风暴建模法53
244 实例解析:一个典型的事件风暴
建模议程56
25 业务平台与中台设计60
26 总结与拓展62
第3章 聚合设计68
31 聚合设计的概念68
311 高聚合低关联71
312 聚合的逻辑一致性74
32 设计聚合的几种方法77
321 改变主谓宾顺序78
322 根据领域事件设计聚合79
323 根据单一职责设计聚合81
324 按时间边界设计聚合83
325 通过事务边界设计聚合87
326 通过ER模型设计聚合89
33 实例解析:订单系统中的聚合
设计95
331 信息拥有者模式97
332 引用模式99
333 奥卡姆剃刀原理100
334 控制者模式101
335 订单状态集中控制实现103
336 做什么和怎么做的分离106
337 在服务中验证聚合107
338 Spring Boot实现110
34 总结与拓展115
第4章 实体和值对象121
41 失血/贫血模型121
42 实体124
421 实体的标识125
422 实体的设计126
423 实体对象的创建128
43 值对象131
431 值对象与实体的区别134
432 用值对象重构138
44 领域服务140
441 领域服务的特征141
442 领域服务与应用服务144
45 仓储147
451 自行实现仓储148
452 结合Builder模式实现仓储151
46 充血模型的设计原则154
461 将公有setter方法变为私有155
462 注重对象的构建157
47 实例解析:论坛系统实体和
值对象设计159
471 聚合根实体是什么?161
472 值对象的设计164
473 状态设计167
474 发帖功能实现170
475 双聚合根173
476 分配职责行为176
477 构建对象必须遵循唯一性179
48 总结与拓展184
第5章 CQRS架构186
51 DDD架构介绍187
511 MVC模式187
512 传统三层架构188
513 传统DDD分层架构191
514 清洁架构194
515 六边形架构198
516 垂直切片架构201
52 CQRS架构的特点203
53 命令和查询分离205
531 查询模型实现206
532 命令模型实现210
533 Command对象212
534 命令和查询的协作216
54 不同的数据访问方式219
541 查询端存储实现220
542 规格模式221
543 命令与查询的同步224
55 CAP定理226
56 领域事件实现数据同步227
57 实例解析:使用Axon框架
实现CQRS231
571 命令端实现233
572 查询端实现236
58 总结与拓展237
第6章 事件溯源241
61 什么是事件溯源?242
62 基于事件溯源的聚合根设计249
621 用事件替代状态249
622 活动与事件253
63 事件溯源的优点260
631 替代分布式事务261
632 事件日志的顺序性263
633 基于事件日志的消息系统265
64 微服务中的分布式事务
实现266
641 引入Saga模式267
642 Saga分布式事务原理267
643 实例解析:账户转账271
65 使用Apache Kafka实现事件
溯源275
66 投射模式280
67 更改数据捕获(CDC)282
68 总结与拓展285
第7章 货物运输系统290
71 领域描述290
72 从流程中发现领域事件294
721 受理流程295
722 作业流程298
73 概念挖掘301
731 划分有界上下文302
732 预订受理上下文304
733 运输作业上下文306
74 预订受理的聚合设计309
741 聚合的发现和命名309
742 聚合设计313
743 状态设计316
744 命令与事件设计317
745 代码实现320
746 设计和实现的差异325
75 运输作业的聚合设计327
751 命令、事件和聚合328
752 有界上下文映射331
753 聚合重构设计334
76 总结与拓展336
短评

复杂软件设计之道:领域驱动设计全面解析与实战

2020-09-02 15:32:18