领域驱动应对业务复杂度

之前的文章提到过,领域驱动设计分成战略层次和战术层次,战略层次我们讨论的很多了,接下来我们主要看下战术层次要搞哪些事情,以及领域驱动如何以架构的形式落地呢。

分层架构

在进行软件系统架构过程中,分层架构是首先会想到的一种架构方式,主要按照职责进行横向划分。

CQRS

这个是我们在通过领域驱动进行架构设计首先想到的一种普世的架构,读写分离,读方向和写方向的的系统瓶颈可以针对性的进行解决和优化。

其核心思想如下:

  • Command:不返回结果,但会改变对象状态

  • Query:返回结果,但是不会改变对象的状态,多次查询对于系统没有其他影响

六边形架构

六边形架构的提出主要是对标分层架构,原有的分层架构可以通过水平方式进行逻辑内聚,但是在同一个平层内其实没有起到隔离的效果,于是就有人提出了六边形架构,也就是提出了“内部”和“外部”的概念。

“内部”能力主要是代表了业务逻辑,“外部”表示应用的驱动逻辑,基础设施及其他应用。后续有人在六边形的六个方向上分别定义了不同的“外部”能力,如:

  • Rest API

  • MQ

  • RPC

  • ES Search

  • ORM 等。

洋葱圈架构

洋葱圈和六边形架构很类似,背后的思想都是保护核心业务逻辑,不受其他设施迭代而影响(业务和非业务的一种分离),非业务逻辑采用适配器方式进行解耦,避免渗透到核心业务中,这样实现了设施替换而业务无感知的效果,业务和设施迭代互不影响。

  • 外层依赖于内层

  • 内层对外层无感知

在洋葱头和领域驱动叠加之后,可以变成一个分层的洋葱头:

Application -> Domain Service -> Domain Model -> Infrastructure

整洁架构

整洁架构是对三层架构的一种改良,将三层中的业务逻辑层进一步拆分成应用层,领域层,基础设施层。

类似于:

  • API层:同程负责RestAPI的web请求,将请求交给逻辑层执行,并返回视图模型viewModel

  • 逻辑层:获取请求输入,组装上下文,输入校验,调用领域服务编排,还可以在这层衔接基础设施,比如MQ做异步调用

  • 领域层:封装了核心的业务逻辑,通过Domain Service和Entities的开放还是对外提供业务逻辑

  • 持久层:承接各种数据源,比如MySql,NoSql,搜索引擎,文件系统等服务

领域驱动解决扩展能力

在简单的业务场景,系统对于扩展性的要求并不高,于是很多程序员对于扩展能力的训练就少一些。但是随着业务发展的越来越快,复杂度逐渐增高,代码中可能通过大量的if-else进行逻辑处理,在架构层面有没有好的应对扩展性的解决方案呢?

以业界流行的中台解决方案(阿里的TMF)来说,一般存在两个很重要的概念:

  • 业务身份

  • 扩展点

业务身份(BizCode)

指的是业务在系统中的唯一标识一个业务或者一个场景的标记,BizCode可以采用类似于Java包命名空间的方式命名,如“ali.tmall”表示的是天猫。

扩展点(ExtensionPoint)

每个业务或者场景都可以实现一个或多个扩展点,业务身份加上扩展点,可以唯一的确定一个扩展实现(Extension)。

有了业务身份和扩展点,可以从框架或者平台纬度实现多租户的管理。不同业务,不同场景都可以实现定制。阿里的中台主要也是围绕于这个思想,实现了一个平台框架的多业务支撑。

约定大于配置

最开始使用MVC架构时,听到过“约定大于配置”这句话,意思是将规则性的东西固化下来,尽量减少随心所欲而带来的复杂度。

我们可以在系统中针对于架构命名,模块命名,规范约束,组件,包等进行命名,实现标准化和约束性,以提高系统的可维护性。

网上找了一个基于DDD和CQRS的架构,通过使用扩展点和元数据提供了系统的扩展性:

总结

不管是分层架构,六边形架构,还是洋葱圈架构,还是整洁架构,我们可以发下一个共同点,就是“核心业务逻辑与技术细节分离”,我们在网关拆分上也是基于这一点做的,核心业务下沉,网关只维护技术相关细节。

核心业务逻辑下沉之后,可以实现领域模型和领域服务的复用,没有技术细节的代码也更易于RD所理解。技术细节不受业务迭代限制,随时可以升级或是丢弃。

领域驱动应对业务复杂度相关推荐

  1. 领域驱动设计--业务架构映射为应用架构(五)

    通过<多维度规划业务架构>,我们获得了由业务领域-业务组件-业务服务三个层次组成的业务架构.虽然是架构,但其本质仍然属于问题空间,其目的在于真实地探索问题空间,了解我们要解决什么样的问题. ...

  2. 如何使用ABP框架(2)三层架构与领域驱动设计的对比

    本文来自长沙.NET技术社区,原创:邹溪源.全文共有8500字,读完需耗时10分钟. 题图来自@pixabay 简述 上一篇简述了ABP框架中的一些基础理论,包括ABP前后端项目的分层结构,以及后端项 ...

  3. c/s三层结构信息系统的三个层次_如何使用ABP框架(2)三层架构与领域驱动设计的对比...

    本文来自长沙.NET技术社区,原创:邹溪源.全文共有8500字,读完需耗时10分钟. 题图来自@pixabay 简述 上一篇简述了ABP框架中的一些基础理论,包括ABP前后端项目的分层结构,以及后端项 ...

  4. 如何使用ABP进行软件开发(2) 领域驱动设计和三层架构的对比

    简述 上一篇简述了ABP框架中的一些基础理论,包括ABP前后端项目的分层结构,以及后端项目中涉及到的知识点,例如DTO,应用服务层,整洁架构,领域对象(如实体,聚合,值对象)等. 笔者也曾经提到,AB ...

  5. 领域驱动设计 软件核心复杂性应对之道_DDD - 领域驱动设计对软件复杂度的应对(上)...

    不管是因为规模与结构制造的理解力障碍,还是因为变化带来的预测能力问题,最终的决定因素还是因为需求.Eric Evans 认为"很多应用程序最主要的复杂性并不在技术上,而是来自领域本身.用户的 ...

  6. 读张逸的领域驱动设计之应对软件复杂度笔记

    2019独角兽企业重金招聘Python工程师标准>>> 张逸的<领域驱动战略设计实战>地址,付费的,价格¥59,还能接受. Eric Evans认为"很多应用程 ...

  7. 【直播回顾】阿里高级开发工程师红文:领域驱动设计实战--如何应对复杂业务...

    主讲人:红文(阿里集团-创新业务事业群-高级开发工程师) 本名:蒋辉文 作者介绍: 中科大计算机硕士 淘宝服务市场商业化交易系统中台研发工程师 钉钉商业化交易系统研发工程师 连续三年参加双十一稳定性保 ...

  8. 领域驱动设计在互联网业务开发中的实践

    前言 至少30年以前,一些软件设计人员就已经意识到领域建模和设计的重要性,并形成一种思潮,Eric Evans将其定义为领域驱动设计(Domain-Driven Design,简称DDD).在互联网开 ...

  9. 领域驱动设计和业务建模的最佳实现模式

    图片来源:pexels.com 做了这么多年项目,不知道你有没有发现一个有趣的现象:有时候面对同一个问题,当我们对它的定义不同,往往最终解决方案的差异也会非常大. 拿我司之前的一个需求来说,客户要求将 ...

最新文章

  1. Ajax的用法之JQuery
  2. shell中的变量赋值
  3. 认识了一个新的手机游戏剖析工具- SnapDragon Profiler
  4. 使用无限生命期Session的方法
  5. Navicat Premium 12安装及常用快捷键
  6. YbtOJ#903-染色方案【拉格朗日插值,NTT,分治】
  7. super构造方法为什么给子类赋值_【Java学习 | Javase】super
  8. 首次!华人获世界科学奖,其海洋蓝色能源技术或解决世界能源需求
  9. 关于mongodb的可视化工具:nosql manager for mongodb
  10. 批量修改Project视图中Prefab的名字
  11. 手机虚拟摄像头_新游 | 打破次元壁障,《猪猪侠AR虚拟使命》现实约战,一切尽在创酷互动!...
  12. 【安全系列】IPSEC ×××之安全基础篇
  13. html中q标签和blockquote标签的区别
  14. java 弹框_java弹框
  15. UBUNTU设置环境变量MALLOC_CHECK_=1检查内存
  16. colab 数据集_Google Colab上的YOLOv4:轻松训练您的自定义数据集(交通标志)
  17. Object对象的内存布局学习总结
  18. iphone引用自定义字体 html,在网页上使用苹果字体
  19. 四相五线步进电机定时器驱动
  20. vmware虚拟机设置静态ip地址

热门文章

  1. 解题报告:luogu P2423 [HEOI2012]朋友圈【最大团转最大点独立集(匈牙利算法+时间戳优化)】
  2. [SCOI2005]栅栏(贪心+二分+dfs)难度⭐⭐⭐⭐
  3. 计算机二级第十七套真题,2012年计算机二级VB第十七套上机试题及解析.doc
  4. 应用程序自定义快捷键
  5. 【iOS工具】rvm、Ruby环境和CocoaPods安装使用及相关报错问题解决(2016 12 15 更新)...
  6. 保存一下dedecms数据库表和字段说明,方便日后查询
  7. 抢车位中的排名bug(比較使用了无符号数)
  8. 利用or构造SQL巧妙注射
  9. [转]Struts 2.1发布
  10. 在leangoo中如何做好需求管理(研发效能)