架构师篇-9、从事件风暴到微服务设计的落地过程

news/2024/7/7 1:35:13 标签: 微服务

用户付款功能第二个版本的设计实现

折扣Service和OrderService拆和不拆是由代码规模决定的。
在这里插入图片描述

单一职责原则(SRP)

  • 软件系统中的每个元素只完成自己职责内的事,将其他的事交给别人去做
  • “职责”通常人理解为一个事情,与该事情相关的事都是它的责任
    一个职责是软件变化的一个原因

第二次需求变更

增加VIP会员功能

  • 对VIP金卡和银卡会员进行不同的折扣
  • 在支付时为VIP会员发放福利
  • VIP会员可以享受某些特权
    遇到需求之后,不要马上coding,而是先回到上一版本的领域模型。

付款功能第三个版本的实现

在这里插入图片描述

第三个版本的领域模型

在这里插入图片描述

第三次需求变更

增加更多的支付方式

  • 支付宝支付
  • 微信支付
  • 工商银行支付
  • 民生银行支付
  • 广发银行支付
  • 招商银行支付

第四个版本的领域模型

在这里插入图片描述

付款功能第四个版本的实现

在这里插入图片描述

领域驱动架构的设计实现

传统的领域驱动设计方式代码
前端:vue
数据接入层:controller
应用层:service
领域层:entity
基础设施层:仓库实现- repository
在这里插入图片描述

今后的设计思路:DDD+低代码。后续不需要写Controller和 Repository,只需要写vue、service、entity

演练领域驱动的设计过程

需求分析-》领域建模-〉设计编码

  • 业务分析:统一语言与事件风暴
  • 领域设计:服务、实体、值对象
  • 微服务拆分:聚合、限界上下文文与领域事件

统一语言建模

业务规则
业务流程
业务痛点
在这里插入图片描述

诊断领域模型

在这里插入图片描述

事件风暴(Event Storming)

事件风暴是一种基于工作坊的实践方法,它可以快速发现业务领域中正在发生的事件,指导领域建模及程序开发。
它是Alberto Brandolini发明的一种领域驱动设计实践方法,被广泛应用于业务流程建模和需求工程。
基本思想是将软件开发人员和领域专家(最好的方式是客户,实际操作起来比较困难,一般都是产品经理)聚集在一起,相互学习。
为了让学习变得更容易,该方法的工作方式类似于头脑风暴,让事件风暴变得很有趣。

事件即事实(Event as Fact)

领域事件:即领域中发生的事实(fact)
在真实世界中,当满足某个条件时,某个发起者会触发某个事件,做某个事情。
事实(fact):是指那些已经发生过的事件。
鉴于过去已经发生的事实不会发生改变,因此信息系统可以将这些事实以信息的形式存储到数据库中,即信息就是一组事实。

事件风暴会议

在这里插入图片描述

  • 事件风暴会议以完成领域模型为目标
  • 参会人员:领域专家和软件开发人员
  • 会议以探讨领域事件开始,从前往后依次梳理,以确保领域中所有事件都能覆盖
  • 项目组成员不断增加各种命令与事件,进而思考与之相关的资源、外部系统与时间
  • 识别模型中可能的聚合以其聚合根
  • 将模型分配到各个限界上下文中,构建上下文地图

案例:在线订餐系统

在这里插入图片描述

领域事件

在这里插入图片描述
领域事件的定义:

  • 过去发生:因此是已xx。
  • 重要:需要记录的重要的内容。
  • 选餐只是一个动作(查询),因此不是一个领域事件的概念。
领域事件分析

在这里插入图片描述
为每一个领域事件去分析,上图为【下单领域事件】:

  • 下单动作用蓝色表示
  • 需要有事件的触发者
    在这里插入图片描述
    在这里插入图片描述
问题域、子域与限界上下文

主题域:核心功能
支撑域:支持主题域的模块,如用户注册
在这里插入图片描述
在这里插入图片描述


http://www.niftyadmin.cn/n/5534710.html

相关文章

通过卷防水上限,解锁手机的新玩法?IP68之间亦有不同

当手机的日常防水已经成了基本功,防水能力的上限便成了新的赛道。 毕竟再谨慎的人,也可能会有手滑的时候。这个时候,一台有着IP68级防水的手机,就能给你提供一份安心。 【IP68是标准上限,不是手机防水上限】 IP68是…

stm32——定时器级联

在STM32当中扩展定时范围:单个定时器的定时长度可能无法满足某些应用的需求。通过级联,可以实现更长时间的定时;提高定时精度:能够在长定时的基础上,通过合理配置,实现更精细的定时控制;处理复杂…

米国政府呼吁抛弃 C 和 C++

在开始前刚好我有一些资料,是我根据网友给的问题精心整理了一份「C的资料从专业入门到高级教程」, 点个关注在评论区回复“888”之后私信回复“888”,全部无偿共享给大家!!! 很多观点认为C 或 C永远不可被…

Zoom使用的基本步骤和注意事项

Zoom是一款功能强大的视频会议软件,广泛应用于远程办公、在线教育、团队协作等多个场景。以下是Zoom使用的基本步骤和注意事项: 一、注册与登录 注册Zoom账户: 访问Zoom官方网站(如zoom.us),点击“注册”…

如何清理电脑内存?让电脑运行如飞!

电脑内存(RAM)的清理对于维持系统的流畅运行至关重要。随着使用时间的增加,系统内存会被各种应用程序和后台进程占用,导致系统响应变慢,甚至出现卡顿现象。通过有效地清理内存,可以提升电脑的性能&#xff…

代码随想录算法训练营第70天图论9[1]

代码随想录算法训练营第70天:图论9 ‍ 拓扑排序精讲 卡码网:117. 软件构建(opens new window) 题目描述: 某个大型软件项目的构建系统拥有 N 个文件,文件编号从 0 到 N - 1,在这些文件中,某些文件依赖于其他文件的…

学习笔记——动态路由——OSPF(OSPF协议的工作原理)

八、OSPF协议的工作原理 1、原理概要 (1)相邻路由器之间周期性发送HELLO报文,以便建立和维护邻居关系 (2)建立邻居关系后,给邻居路由器发送数据库描述报文(DBD),也就是将自己链路状态数据库中的所有链路状态项目的摘要信息发送给邻居路由器…

解决mybastis-plus加入逻辑删除SQL语句自动拼接未删除的问题

配置逻辑删除 在bootstrap.yaml中加入逻辑删除配置 mybatis-plus:global-config:db-config:logic-delete-field: isDeleted # 全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置步骤2)logic-delete-value: true # 逻辑已删除值(默认为 1)logic-not-delete-value: …