当前位置: 首页 > news >正文

《别再写Service地狱了!用DDD重构我的项目全过程》

1. DDD 是什么

DDD 是一种软件设计方法。也就是说 DDD 是指导我们做软件工程设计的一种手段,它提供了用切割工程模型的各类技巧,如;领域、界限上下文、实体、值对象、聚合、工厂、仓储等。通过 DDD 的指导思想,我们可以在前期投入更多的时间,更加合理的规划出可持续迭代的工程设计。

在 DDD 中有一套共识的工程两阶段设计手段,包括;战略设计、战术设计。

  1. 战略设计,主要以应对复杂的业务需求,通过抽象、分治的过程,合理的拆分为独立的多个微服务,从而分而治之。与之评价拆分的是否合理,则是在需求开发上线时候,是否每次都大量操作多个微服务开发和上线。这样的战略设计是一种失败的微服务单体设计。所以少数几个中等规模的单体应用,周围环绕着一个服务生态系统,这更有意义。你实际上并没有构建微服务 @贾斯汀·埃瑟里奇
  2. 战术设计,在这个范畴下,主要以讨论如何基于面向对象思维,运用领域模型来表达业务概念。通常在不做领域模型设计的架构,也就是通常映射到 MVC 三层架构下,Service + 数据模型的开发模式,会让 Service 扁平的、大量的,平铺出非常复杂的业务逻辑代码。再加上行为对象与功能逻辑的分离,贫血模型的开发方式,让行为对象的不断交叉使用,也是让系统不断增加复杂度,并到难以维护的根因。所以这一阶段要设计每一个可以表达领域概念的模型,并运用实体、聚合、领域服务来承载。

2. DDD 的概念

什么是充血模型,领域内都包括什么,实体、聚合、值对象,有什么区别?这样一些"为什么"的概念,也是战术设计过程中非常重要的知识项。搞清楚它们才能做 DDD 设计。

2.1 充血模型

充血模型,指将对象的属性信息与行为逻辑聚合到一个类中,常用的手段如在对象内提供属于当前对象的信息校验、拼装缓存Key、不含服务接口调用的逻辑处理等。

  1. 这样的方式可以在使用一个对象时,就顺便拿到这个对象的提供的一系列方法信息,所有使用对象的逻辑方法,都不需要自己再次处理同类逻辑。
  2. 但不要只是把充血模型,仅限于一个类的设计和一个类内的方法设计。充血还可以是整个包结构,一个包下包括了用于实现此包 Service 服务所需的各类零部件(模型、仓储、工厂),也可以被看做充血模型。
  3. 同时我们还会再一个同类的类下,提供对应的内部类,如用户实名,包括了,通信类、实名卡、银行卡、四要素等。它们都被写进到一个用户类下的内部子类,这样在代码编写中也会清晰的看到子类的所属信息,更容易理解代码逻辑,也便于维护迭代。

2.2 领域模型

领域模型指特定业务领域内,业务规则、策略以及业务流程的抽象和封装。在设计手段上,通过风暴模型拆分领域模块,形成界限上下文。最大的区别在于把原有的众多 Service + 数据模型的方式,拆分为独立的有边界的领域模块。每个领域内创建自身所属的领域对象(实体、聚合、值对象)、仓储服务(DAO 操作)、工厂、端口

http://www.jsqmd.com/news/706748/

相关文章:

  • 成都地区、H型钢、294X200X8X12、Q235B、包钢、现货批发供应 - 四川盛世钢联营销中心
  • 深度学习工程实践:从数据准备到模型部署全流程指南
  • 湖州德清县GEO 代理适合跨境电商日常使用吗
  • 5G市场正步入精细化与战略性发展新阶段
  • 【2026年网易雷火春招- 4月26日-第一题- 喵居】(题目+思路+JavaC++Python解析+在线测试)
  • 成都地区、H型钢、390X300X10X16、Q235B、包钢、现货批发供应 - 四川盛世钢联营销中心
  • MiroFish-Offline:本地化AI模型部署与调优实战指南
  • AI群演请就位——个人博客(三)
  • AI 时代最大的谎言:你以为在学习,其实在欠债—思维决定上限的反焦虑框架
  • 达梦数据库-数据库存储加密02-记录总结
  • 成都地区、H型钢、400X400X13X21、Q235B、包钢、现货批发供应 - 四川盛世钢联营销中心
  • 每日一学:设计模式之观察者模式
  • 从虚拟化到容器化:华为云弹性计算架构的演进与实践
  • 重庆二手房历史交易信息2015-2023年
  • R语言机器学习模型保存与部署实战指南
  • 2026就近回收技术解析:西餐厅回收/高价回收/上门回收/专业回收/中餐馆回收/二手货回收/厨房设备回收/奶茶店回收/选择指南 - 优质品牌商家
  • NVIDIA Nemotron 3架构解析:智能体AI与混合Mamba-Transformer MoE设计
  • RNN与LSTM:序列预测模型原理与实战技巧
  • 2026无纺布中药煎药袋标杆名录:水果果框套袋透气袋、汽车配件包装透气袋、热封款无纺布袋、缝纫款无纺布袋、蔬菜框套袋透气袋选择指南 - 优质品牌商家
  • 想给照片换背景底色?2026 年这几款工具+1 个微信小程序的搭配建议
  • RAGFlow · 第 3 章:第一节 RAGFlow 配置参数全景图与实验结论
  • 机器学习概率校准:原理与实践指南
  • Proxmox VE Ceph 超融合集群落地实战
  • 成都地区、H型钢、340X250X9X14、Q235B、包钢、现货批发供应 - 四川盛世钢联营销中心
  • 5分钟快速上手:崩坏星穹铁道游戏自动化脚本终极指南
  • 紧急预警:MCP 1.8+版本中隐藏的跨模态梯度坍塌风险(附3行代码热修复方案)
  • 商业航天与航空安全场景下抗辐射 MCU 选型、应用实践及发展趋势
  • 【紧急更新】VS Code 1.92+已默认启用MCP v2.1协议!你的插件生态是否已通过RFC-8921合规性审计?
  • Superpowers:可视化编排AI智能体,构建协作式应用开发平台
  • PyTorch实现逻辑回归:从原理到实战