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

领域驱动设计(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认为我们在这一点上已经迷失并且在偏离方向。我们已经开发了实现技术,并且又独立开发了新的建模技术,现在我们必须将它们结合起来,这样来自模型的理念能够直接反射到代码中,这样的话,会在构建分布式系统方面取得真正的突破。

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

相关文章:


原文地址:http://www.infoq.com/cn/news/2018/04/reactive-actors-eventstorming


.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/321780.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

4、java中的流程控制(程序结构)

说一下java的流程控制(程序结构),其实对于计算机而言,无非就那几类执行流程(程序结构),程序从头到尾依次执行每一行代码,这就是顺序结构;也可能在执行过程中遇到条件判断…

jzoj1402-偷懒的小X【贪心】

正题 题目链接:https://jzoj.net/senior/#contest/show/2940/0 题目大意 一颗满二叉树,第iii个点的儿子是i∗2i*2i∗2和i∗21i*21i∗21,然后nnn个数填入,求一个满足小根堆性质的字典序最大的路线。 解题思路 我们计算出每个点下面有多少个…

动态规划训练18 [免费馅饼 HDU - 1176 ]

免费馅饼 HDU - 1176 这也是一道比较简单的动态规划 dp[i][j]表示到时间i,位置为j所能采集的最大馅饼数量 状态转移非常好写 dp[i][j] max{dp[i-1][j],dp[i-1][j-1],dp[i-1][j1]} T[j][i] 其中T[j][i]表示的是时间为i,位置为j落下的馅饼的数量 #in…

站在巨人肩上的.NET Core 2.1

.NET Core 1.0自发布两年以来,得到了开发者群体相当高地认可。 下图来自Stack overflow survey 2018的统计:.NET Core已经成为前五的主流框架工具,现今借鉴了优秀的设计原则和开发体验可谓站在巨人肩上。这一切归功于.NET团队认识和总结了大量…

5、java中的数组

1、简介 数组是一种具有随机存取特性的数据结构,是内存上一段连续区域的表示,是实现顺序存储的基础,数组只能用于存储同一类型的数据。数组的长度在初始化时定义之后就不可更改,并且在初始化数组时必须指定数组的长度。 2、数组…

jzoj1403-渡河【SPFA】

正题 题目链接:https://jzoj.net/senior/#contest/show/2940/1 题目大意 一个n∗nn*nn∗n的图,从000走到111价格为1。kkk个询问,询问一个点离边界的最小价格。 解题思路 反向从边界开始跑SPFASPFASPFA即可。 codecodecode #pragma GCC optimize(&quo…

动态规划训练19、最短路 [Help Jimmy POJ - 1661 ]

Help Jimmy POJ - 1661 题意:大致是一个人从某个点开始下落,下落的速度是1m/s,然后在平台上的时候可以左右移动,移动的速度也是1m/s,但是这里有一个限制,就是说每次下落的距离不能超过一个给定的数值。问你…

【活动(北京)】Global Azure Bootcamp

活动议程活动内容08:30-08:50报到08:50-09:10活動开场Study4 - 陈科融(MVP)STB Chain Foundation - 劉海峰(MVP)MVP Program - Christina Liang(MVP CPM)09:10-10:00区块链让软件资产化成为现实刘海峰(MVP) - STBChain Foundation主席10:10-11:00基于Azure PaaS的网站应用刘元纶…

jzoj1404-菱形内的计数【模拟】

正题 题目链接:https://jzoj.net/senior/#main/show/1404 题目大意 给出一个菱形中有一些边,求有多少个中间没有边的平行四边形。 解题思路 我们将一个平行四边形拆成两个等腰三角形和一个平行于菱形中间对角线的平行四边形,我们可以判断上面那个等腰…

6、java中的排序算法

1、简介 排序是将元素按着指定关键字的大小递增或递减进行数据的排列,排序可以提高查找的效率 2、排序算法的分类 排序算法可大致分为四类七种,具体分类如下: 插入排序:直接插入排序、希尔排序 交换排序:冒泡排序、…

用.NET Core实现装饰模式和.NET Core的Stream简介

该文章综合了几本书的内容.某咖啡店项目的解决方案某咖啡店供应咖啡, 客户买咖啡的时候可以添加若干调味料, 最后要求算出总价钱.Beverage是所有咖啡饮料的抽象类, 里面的cost方法是抽象的. description变量在每个子类里面都需要设置(表示对咖啡的描述).每个子类实现cost方法, …

动态规划训练20 [Treats for the Cows POJ - 3186 ]

Treats for the Cows POJ - 3186 简单的区间DP&#xff0c;就不解释了。 #include<iostream> #include<cstdio> using namespace std; const int INF1e9; const int maxn2005; int n, a[maxn]; int dp[maxn][maxn]; int main() {scanf("%d",&n);for(…

7、java中的面向对象思想和体现

java是一种面向对象的程序设计语言&#xff0c;在程序中使用对象来描述具体的事物&#xff0c;当多个事物具有共同的特点时&#xff0c;可以将事物的共同特点进行抽象&#xff0c;然后封装成一个包含事物共同特点的集合&#xff0c;在java中叫做封装成一个类&#xff0c;可以将…

jzoj1405-电缆建设【贪心,最小生成树】

正题 题目链接:https://jzoj.net/senior/#main/show/1405 题目大意 两个平行于xxx轴的线上有若干个点&#xff0c;求连接所有点需要多少距离的线。 解题思路 在同一平行线上的相邻的连边&#xff0c;然后在不同的上面的话就离最近的两个&#xff0c;跑最小生成树即可。 code…

动态规划训练21 [FatMouse and Cheese HDU - 1078 ]

FatMouse and Cheese HDU - 1078 这道题需要说一说&#xff0c;定义dp[x][y]表示从点(x,y)出发&#xff0c;每次走不超过k步&#xff0c;所能吃到的最大量。 有点难搞的是&#xff0c;这里递归的顺序不好确定&#xff0c;所以采用自顶向下的记忆化搜索的方式&#xff08;不用担…

这个拖后腿的“in”

问题之源C# 7.2推出了全新的参数修饰符in&#xff0c;据说是能提升一定的性能&#xff0c;官方MSDN文档描述是&#xff1a;Add the in modifier to pass an argument by reference and declare your design intent to pass arguments by reference to avoid unnecessary copyin…

P4310-绝世好题【位运算,dp】

正题 题目链接:https://www.luogu.org/problem/P4310 题目大意 一个长度为nnn的序列&#xff0c;求一个最长的子序列使得每个数&\&&前一个数不为0。 解题思路 因为是&\&&不为0&#xff0c;所以只要有一位都为1即可。 用fif_ifi​表示以第iii个结尾…

8、java中的内部类

根据类定义时所在的位置不同可以将内部类分为四大类&#xff1a;成员内部类、方法内部类、静态内部类、匿名内部类。 成员内部类 顾名思义成员内部类定义在外部类的成员变量位置&#xff0c;相当于外部类的一个成员。将成员内部类当成当前封装类中的一个成员即可&#xff0c;…

Surging 微服务框架使用入门

前言本文非 Surging 官方教程&#xff0c;只是自己学习的总结。如有哪里不对&#xff0c;还望指正。 我对 surging 的看法我目前所在的公司采用架构就是类似与Surging的RPC框架&#xff0c;在.NET 4.0框架上搭建Socket RPC&#xff0c;通过分组轮询的方式调度RPC&#xff0c;经…

动态规划训练22 [Milking Time POJ - 3616 ]

Milking Time POJ - 3616 说实话这道题目非常简单&#xff0c;本质上就是 多段有向图的求最大值问题。稍微变化的地方在于这个的的有向边没有那么明显 &#xff0c;而是需要自己去寻找 如果任务i到任务j之间存在有向边的话&#xff0c;那么一定有这个关系成立&#xff0c;即&a…