写点什么

使用 DDD、事件风暴和 Actor 来设计反应式系统

  • 2018-04-01
  • 本文字数:1491 字

    阅读完需:约 5 分钟

看新闻很累?看技术新闻更累?试试下载 InfoQ 手机客户端,每天上下班路上听新闻,有趣还有料!

领域驱动设计(domain-driven design,DDD)通常在微服务领域用于查找边界(限界上下文)。同样来自DDD 的聚合(aggregate)对于定义持久化和一致性的范围来讲也是很重要的。 但是,并不是领域驱动设计中的所有内容都适合微服务, Lutz Huehnken 在柏林举办的 microxchg 2018 的演讲中讨论了如何使用 DDD、事件风暴(Event Storming)和基于 Akka Lagom 框架来构建反应式系统,在这个过程中模型与实现会按照1-1 的方式进行映射。

在DDD 中,传统上会关注系统的静态结构,当我们与领域专家交流的时候会聆听他们的名词。Huehnken 是一位独立咨询顾问,对他来讲关注静态属性通常会导致糟糕的边界。因此,他主张我们应该关注动态性和事件。在设计的初期阶段,至关重要的并不是事物,而是所发生的事情。

事件风暴

事件风暴主要是来自DDD 社区的一个工作坊,用于快速探索复杂的业务领域。在这个过程中,会使用一面大墙作为建模面,并使用贴纸来代表模型。我们将业务人员和开发人员聚集起来,并采用事件的方式查找领域中所发生的事情。当找到事件时,会尝试沿着一个时间线对它们进行排序。随后,我们会添加触发每个事件的命令。Huehnken 在这里没有基于实体看上去的从属关系创建聚合,而是希望能够根据命令流和事件而生成聚合。这会给聚合带来不同的视角,它会对命令和事件一起进行逻辑分组,他相信这种方式能够为我们带来更好的边界划分,并且有助于将聚合分割到不同的服务中。

在Huehnken 的经验中,事件风暴是一个强大的工具,在一些较大规模的场景中更是如此,但是它可以用于不同的级别。他发现我们还可以将其用到一个更加技术化的级别,用于建模服务和聚合。这种方式的一个巨大优势就是能够将模型和实现匹配起来,这在DDD 中是非常重要的。

反应式系统

反应式系统指的是构建具备即时响应性、弹性、适应性以及消息驱动特征的系统。实现这些特征的方式是异步消息。对于Huehnken 来说,微服务的关键点在于隔离、快速反应并且能够在部署新版本服务时不影响系统的其他组成部分,所以对他来说,这两个概念非常具有互补性,我们需要反应式的微服务。

实现反应式系统的教科书式技术是 Actor ,但是 Huehnken 认为这种模型并不像他想象中的那样被广泛采用,他相信造成这一点的原因在于从单体模型进行转移所需的思想方式转变。在单体模型中,我们可以访问任何的内容,甚至可以跨越已存的逻辑边界。在真正的分布式系统中,会具有网络边界,我们无法以整体的方式访问系统。涉及到多个聚合的业务进程可能会需要像 sagas 这样的模式。现在,我们还要告别全局状态,在分布式系统中,每个服务是本地化的,已经过去的事情要通过事件来表示。

Huehnken 认为我们已经有了一个非常有趣的采用 Actor 的实现技术。现在有多个可用的框架,包括 Erlang 和 Akka。Lagom 是一个更新、更具倾向性的微服务框架,它基于 Akka、 CQRS 事件溯源(event sourcing)。因为思维方式的挑战,人们在构建复杂异步解耦的系统时还较为困难,但是如果我们想要将建模技术和实现技术结合起来,这将是一个非常好的机会。

在DDD 中,非常重要的一点在于代码要表述模型的概念。Huehnken 认为我们在这一点上已经迷失并且在偏离方向。我们已经开发了实现技术,并且又独立开发了新的建模技术,现在我们必须将它们结合起来,这样来自模型的理念能够直接反射到代码中,这样的话,会在构建分布式系统方面取得真正的突破。

会议演讲的视频进行了录制,其中有一部分已经发布,更多的视频稍后会发布。

查看英文原文 Designing Reactive Systems Using DDD, Event Storming and Actors

2018-04-01 19:005078

评论

发布
暂无评论
发现更多内容

新书上市 | 连载 5 年,千万读者追更,这本书讲透了通信背后的故事!

图灵社区

通信技术 科技史

从用户到开发者是一种思维进化过程 | 访 StarRocks Committer 周威

StarRocks

2022-09-01:字符串的 波动 定义为子字符串中出现次数 最多 的字符次数与出现次数 最少 的字符次数之差。 给你一个字符串 s ,它只包含小写英文字母。请你返回 s 里所有 子字符串的 最大波

福大大架构师每日一题

算法 rust语言 福大大

Web3大行其道,为何说Zebec值得投资人期待?

BlockChain先知

Predicate

急需上岸的小谢

9月月更

Web3的流支付代表Zebec,熊市布局的价值逻辑

鳄鱼视界

构筑校园  “云资环”助力精准防控

科技云未来

实践分享!GitLab CI/CD 快速入门

北京好雨科技有限公司

企业号九月金秋榜 Kuberetes

一文看懂Mysql锁

六月的雨在InfoQ

MySQL MySQL锁 9月月更 Mysql死锁 Mysql锁粒度

maven入门

楠羽

maven 笔记 9月月更

k8s自定义controller三部曲之一:创建CRD(Custom Resource Definition)

程序员欣宸

Kubernetes k8s 9月月更

高并发场景下,6种方案,保证缓存和数据库的最终一致性!

C++后台开发

数据库 缓存 高并发 后端开发 C++开发

深耕隐私计算技术,瓴羊DataTrust团队喜获殊荣

瓴羊企业智能服务

基于 xbot 实现微信关键词自动回复

Hanson

微信 微信机器人 自动回复

跟着卷卷龙一起学Camera--黑电平Blacklevel

卷卷龙

ISP camera 9月月更

C++学习------cassert头文件的作用与源码学习

桑榆

c++ 9月月更

【CSS·显示类型】 block、inline以及inline-block

翼同学

CSS 前端 9月月更

Nacos 安装教程(史上最详细保姆级教程)

nacos SpringCloud 9月月更

# 靠谱:开源IM项目OpenIM压测程序介绍-自己动手压测性能和稳定性

Geek_1ef48b

leetcode 206. Reverse Linked List 反转链表(简单)

okokabcd

LeetCode 数据结构与算法

高级产品经理必备素养

产品海豚湾

产品经理 职业发展 商业化 9月月更 产品价值

从零到一,教你搭建「CLIP 以文搜图」搜索服务(二):5 分钟实现原型原创

Zilliz

机器学习 深度学习 搜索引擎

万物皆可集成系列:低代码对接企企云实现数据集成

葡萄城技术团队

Linux面试最高频的5个基本问题

千锋IT教育

华为云WeLink直播助力高校毕业典礼:这届毕业生,我们云上嗨

科技云未来

南阳蓝天燃气携手WeLink共创数字蓝天

科技云未来

关于链路追踪所需要了解的知识

穿过生命散发芬芳

链路追踪 9月月更

数据中心网络架构的需求原则及策略

阿泽🧸

数据中心 9月月更

数据可视化系列教程之组件构成

云智慧AIOps社区

前端 低代码 开源项目 数据可视化 可视化大屏

测试需求平台3-登录打通和产品列表功能实现

MegaQi

测试平台开发教程 9月月更

玖章算术受邀参加红杉Talk「创新的复利」科技专场,共同探讨云计算的前世今生

数据库 数据复制 数据管理 数据备份 玖章算术

使用DDD、事件风暴和Actor来设计反应式系统_语言 & 开发_Jan Stenberg_InfoQ精选文章