热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

事件风暴研讨会备忘单

事件风暴是软件系统的快速设计技术,涉及技术人员和领域专家业务分析师。它最适合领域驱动设计环境,并倾向

事件风暴是软件系统的快速设计技术,涉及技术人员和领域专家/业务分析师。它最适合领域驱动设计环境,并倾向于/准备事件溯源和CQRS。该技术最初由Alberto Brandolini引入,由Vaughn Vernon在Domain Driven Design Distilled中采用。它也是他的iDDD研讨会系列的一部分。

该备忘单旨在提供有关准备和促进事件风暴研讨会的简短见解。它并非旨在对该主题进行完整的介绍,需要事先了解DDD和事件风暴才能负责任地使用本文档。

所需材料

  • 卷纸,用于创建建模曲面。例如在宜家(Mala, http ://www.ikea.com/de/de/catalog/products/80324072/ 或亚马逊 https://www.amazon.de/gp/product/B005OBO1LO )
  • 粘性便笺。Vaughn Vernon推荐使用7,6 x 7,6 cm超粘性品种。您需要以下颜色:橙色,浅蓝色,浅黄色,绿色,粉红色,紫色/红色,淡紫色。我找到了Post It系列Marrakesh(例如https://www.amazon.de/gp/product/B016OON3UO/)和Energy(例如 https://www.amazon.de/gp/product/B006JCQJJY )。确保你有足够的
  • 如果您还想绘制UI模拟,人物角色或验收测试用例,您也可以添加更多种类的胶粘物。
  • 细头记号笔或水笔。每个参与者至少一个,但最好有两种颜色,例如黑色和蓝色。不要使用标准的活动挂图标记,因为它们对于选定的粘滞便笺来说太大了,而是更精细的。我发现Stabilo'Greenpoint L0.8运行良好(https://www.amazon.de/dp/B004HV1N8Q/)。
  • 更大的记号笔。标准活动挂图标记效果很好。你不能错过Neuland标记,例如 https://de.neuland.com/marker-stifte/neuland-marker/neuland-no.one-keilspitze-2-6-mm-einzelfarben.html
  • 胶带。使用电工胶带将纸卷和可能的皱纹胶带放在一起,以便添加额外的纸条。

准备:

事前:

  • 邀请域专家和开发人员。就个人而言,我的目标是不超过8.但由于建模空间很大,讨论组将会出现,因此更多的人也可以很好地工作。
  • 安排会话不超过2或3个小时。计划后续会议。

在会议室准备

  • 从房间里取走椅子。人们应该到处走走。正如阿尔贝托所说,座位是有毒的。
  • 提前准备思路,或者,对于初次参与者,按照 执行中的 描述迭代地创建图例。您可以使用预先准备好的 卡片, 例如本文档附带的 卡片 。
  • 准备建模空间。使用贴在大墙上的纸卷。1 mx 10 m应视为最小尺寸。越大越好。准备好扩大空间。
  • 布置粘滞便笺和标记。

执行

您可以在下面按照Vaughn Vernon推荐的顺序进行。可以在后续步骤中添加其他人工制品,但重要的是大致遵循: 事件→命令→聚合→边界→查看顺序。

  1. 创建或排列图例,以便所有参与者都能很好地理解颜色注释/注释的语义。
  2. 用橙色便签代表领域事件并将它们放置在业务流程(=时间序列)顺序的建模空间中。该名称是过去时的名词/动词组合,例如。ItemOrdered
  3. 如果问题领域与流程或questions出现没有能够得到立即解析的概念,使用紫色或红色的便签标注。
  4. 某些领域事件将形成业务流程运行。用淡紫色标记流程的名称,并从事件流程到业务流程绘制一个箭头。
  5. 当您认为已捕获大多数领域事件时,请关注创建这些事件的命令。把它们靠在引起它们的事件的淡蓝色上。过程是在时间轴上从左到右进行。这个名字就像是一个动作OrderItem(Order是一个动词)。
  6. 如果特定用户角色执行命令,请注意在命令下方使用黄色。我喜欢绘制简笔画来区分它们。
  7. 当您认为自己拥有所有命令时,请将聚合放在黄色便签上,并将它们放在此聚合上执行的命令与其导致的事件之间。这个名字就像一个名词“Item条目”,如果多次使用聚合,请创建副本并将其重复放在时间轴上。
  8. 将有界上下文(实线)和子域(虚线)绘制到建模表面上。只有当你觉得你已经足够了解边界时,你才应该这样做。使用粉红色标记命名上下文。
  9. 绘制箭头以显示事件在您的上下文之间流动的方向。
  10. 识别用户在系统中执行任务所需的视图。将它们放在聚合下方的绿色便签上。

可选添加:

  • UI模拟与界面视图
  • 重要测试的验收测试草图
  • 用户角色
  • 阅读模型

上文中提到的各种颜色的语义如下所示,以供参考。

  • 领域事件 - 橙色
  • 命令 - 浅蓝色
  • 聚合 - 黄色
  • 问题 - 红色或紫色
  • 用户角色/角色 - 黄色与棒图
  • 意见 - 绿色
  • 有界上下文- 实线,粉红色的笔记
  • 子域名 - 虚线
  • 事件流程 - 箭头

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 我们


推荐阅读
  • Spring Boot使用AJAX从数据库读取数据异步刷新前端表格
      近期项目需要是实现一个通过筛选选取所需数据刷新表格的功能,因为表格只占页面的一小部分,不希望整个也页面都随之刷新,所以首先想到了使用AJAX来实现。  以下介绍解决方法(请忽视 ... [详细]
  • 深入理解:AJAX学习指南
    本文详细探讨了AJAX的基本概念、工作原理及其在现代Web开发中的应用,旨在为初学者提供全面的学习资料。 ... [详细]
  • JavaScript 跨域解决方案详解
    本文详细介绍了JavaScript在不同域之间进行数据传输或通信的技术,包括使用JSONP、修改document.domain、利用window.name以及HTML5的postMessage方法等跨域解决方案。 ... [详细]
  • 探讨了在HTML表单中使用元素代替进行表单提交的方法。 ... [详细]
  • 本文探讨了如何在PHP与MySQL环境中实现高效的分页查询,包括基本的分页实现、性能优化技巧以及高级的分页策略。 ... [详细]
  • 本文探讨了如何通过优化 DOM 操作来提升 JavaScript 的性能,包括使用 `createElement` 函数、动画元素、理解重绘事件及处理鼠标滚动事件等关键主题。 ... [详细]
  • 本文详细介绍了JQuery Mobile框架中特有的事件和方法,帮助开发者更好地理解和应用这些特性,提升移动Web开发的效率。 ... [详细]
  • 理解浏览器历史记录(2)hashchange、pushState
    阅读目录1.hashchange2.pushState本文也是一篇基础文章。继上文之后,本打算去研究pushState,偶然在一些信息中发现了锚点变 ... [详细]
  • 本文详细介绍了 Java 中 org.w3c.dom.Node 类的 isEqualNode() 方法的功能、参数及返回值,并通过多个实际代码示例来展示其具体应用。此方法用于检测两个节点是否相等,而不仅仅是判断它们是否为同一个对象。 ... [详细]
  • ABP框架是ASP.NET Boilerplate的简称,它不仅是一个开源且文档丰富的应用程序框架,还提供了一套基于领域驱动设计(DDD)的最佳实践架构模型。本文将详细介绍ABP框架的特点、项目结构及其在Web API优先架构中的应用。 ... [详细]
  • 本文探讨了 Java 中 HttpClient 和 HtmlUnit 的区别,重点介绍了它们的功能和应用场景。 ... [详细]
  • 本文探讨了异步编程的发展历程,从最初的AJAX异步回调到现代的Promise、Generator+Co以及Async/Await等技术。文章详细分析了Promise的工作原理及其源码实现,帮助开发者更好地理解和使用这一重要工具。 ... [详细]
  • 尽管在WPF中工作了一段时间,但在菜单控件的样式设置上遇到了一些基础问题,特别是关于如何正确配置前景色和背景色。 ... [详细]
  • 本文详细介绍如何在 Apache 中设置虚拟主机,包括基本配置和高级设置,帮助用户更好地理解和使用虚拟主机功能。 ... [详细]
  • 本文详细介绍了如何在最新版本的Xcode中重命名iOS项目,包括项目名称、应用名称及相关的文件夹和配置文件。通过本文,开发者可以轻松完成项目的重命名工作。 ... [详细]
author-avatar
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有