使用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,一经查实,立即删除!

相关文章

站在巨人肩上的.NET Core 2.1

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

5、java中的数组

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

动态规划训练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的网站应用刘元纶…

6、java中的排序算法

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

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

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

这个拖后腿的“in”

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

Surging 微服务框架使用入门

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

RabbitMQ教程C#版 - 工作队列

先决条件本教程假定RabbitMQ已经安装,并运行在localhost标准端口(5672)。如果你使用不同的主机、端口或证书,则需要调整连接设置。从哪里获得帮助如果您在阅读本教程时遇到困难,可以通过邮件列表联系我们。1.工作队列&…

IdentityServer4实战 - 基于角色的权限控制及Claim详解

一.前言大家好,许久没有更新博客了,最近从重庆来到了成都,换了个工作环境,前面都比较忙没有什么时间,这次趁着清明假期有时间,又可以分享一些知识给大家。在QQ群里有许多人都问过IdentityServer4怎么用Role…

11、java中的I/O流(1)

我对于流的理解是这样的,计算机的本质本来就是对输入的数据进行操作,然后将结果输出的一种工具,数据在各个数据源节点之间进行流动,感觉流就是对这种状态的一种抽象,一个数据流表示的就是一系列数据序列,ja…

ASP.NET Core 集成测试

集成测试集成测试,也叫组装测试或联合测试。在单元测试的基础上,将所有模块按照设计要求(如根据结构图)组装成为子系统或系统,进行集成测试。实践表明,一些模块虽然能够单独地工作,但并不能保证…

使用C#开发Android应用之WebApp

近段时间了解了一下VS2017开发安卓应用的一些技术,特地把C#开发WebApp的一些过程记录下来,欢迎大家一起指教、讨论,废话少说,是时候开始表演真正的技术了。。1、新建空白Android应用2、拖一个WebView控件进来3、打开模拟器Genymot…

ASP.NET Core依赖注入深入讨论

这篇文章我们来深入探讨ASP.NET Core、MVC Core中的依赖注入,我们将示范几乎所有可能的操作把依赖项注入到组件中。依赖注入是ASP.NET Core的核心,它能让您应用程序中的组件增强可测试性,还使您的组件只依赖于能够提供所需服务的某些组件。举…

使用静态基类方案让 ASP.NET Core 实现遵循 HATEOAS Restful Web API

Hypermedia As The Engine Of Application State (HATEOAS)HATEOAS(Hypermedia as the engine of application state)是 REST 架构风格中最复杂的约束,也是构建成熟 REST 服务的核心。它的重要性在于打破了客户端和服务器之间严格的契约&…

【招聘(北京)】.NETCORE开发工程师(微服务方向)

组织:华汽集团北京研发中心位置:北京市朝阳区焦奥中心官网:www.sinoauto.com邮箱:taoxu.weisinoauto.com 项目:打造面向国内汽车后市场用户的一站式云服务平台(华汽云),形态包括B2B、…

确保线程安全下使用Queue的Enqueue和Dequeue

场景是这样,假设有一台设备会触发类型为Alarm的告警信号,并把信号添加到一个Queue结构中,每隔一段时间这个Queue会被遍历检查,其中的每个Alarm都会调用一个相应的处理方法。问题在于,检查机制是基于多线程的&#xff0…

编写一个Java程序,其中包含三个线程: 厨师(Chef)、服务员(Waiter)和顾客(Customer)

编写一个Java程序,其中包含三个线程: 厨师(Chef)、服务员(Waiter)和顾客(Customer)。他们的行动如下: 厨师准备菜肴,每次准备一个。服务员等待菜肴准备好,然后将其送到顾客那里。顾客等待服务员送来菜看后才开始吃。所有三个角色应该循环进行…

Hangfire使用ApplicationInsigts监控

起因我司目前使用清真的ApplicationInsights来做程序级监控。(ApplicationInsights相关文档: https://azure.microsoft.com/zh-cn/services/application-insights/ )其实一切都蛮好的,但是我们基于Hangfire的Job系统却无法被Ai所监控到&#…

NET主流ORM框架分析

接上文我们测试了各个ORM框架的性能,大家可以很直观的看到各个ORM框架与原生的ADO.NET在境删改查的性能差异。这里和大家分享下我对ORM框架的理解及一些使用经验。ORM框架工作原理所有的ORM框架的工作原理都离不开下面这张图,只是每个框架的实现程度不同…