云计算设计模式(七)——事件获取模式

简介: 云计算设计模式(七)——事件获取模式 使用仅追加存储到记录完整一系列描述在一个域上取数据,而不是存储仅仅是当前的状态,从而使存储区可以被用来实现该域对象的动作事件。

云计算设计模式(七)——事件获取模式


使用仅追加存储记录完整一系列描述一个数据,而不是存储仅仅是当前的状态,从而使存储区可以被用来实现该域对象的动作事件。该图案可以通过避免需要同步的数据模型商业领域简化复杂的结构域的任务;提高性能,可扩展性和响应能力;提供交易数据的一致性;并保持完整的审计跟踪和记录,可能使补偿措施

背景和问题


大多数应用程序使用数据,典型的方法是应用通过更新它作为用户使用数据保持数据的当前状态例如,在传统的创建,读取,更新和删除(CRUD)模型的典型数据处理将是存贮器中读出的数据进行一些修改,以使其和更新的数据的当前状态与新的值时─常常通过使用锁定数据的事务。

CRUD方法有一定的局限性
•在CRUD系统直接执行更新操作数据存储可能会影响性能和响应能力并限制可扩展性因为它需要处理开销的事实
•在具有许多并发用户的协作数据更新冲突更可能发生,因为在更新操作发生数据单个项目。
•除非有另外的审核机制,它记录一个单独的日志的每个操作的详细内容,历史记录丢失


注意:

对于CRUD方法的局限性有了更深的了解请参见“CRUD,只有当你能负担得起MSDN上

 

解决方案


事件获取模式定义了一个方法来处理操作是受一个事件序列其中的每一个记录在仅追加存储驱动的数据应用程序代码发送一系列命令性描述上发生的数据的情况下存储,在那里它们被持久保存的每个动作的事件。每个事件都表示一组数据更改AddedItemToOrder

事件持久保存在一个事件存储在充当真理记录系统的源权威数据给定的数据元素或信息有关的数据的当前状态。事件存储通常发布这些事件让消费者能够得到通知,如果需要,可以处理它们。消费者可以,例如,启动应用的事件的动作的其他系统的任务或执行完成操作所需的任何其他相关联的动作注意,生成该事件的应用程序代码从订阅该事件的系统去耦。

事件存储公布了事件的典型用途是保持实体化视图应用程序中的行动改变他们,与外部系统的集成。例如,系统可保持用于填充UI部分的客户订单实体化视图。随着应用增加了新的订单增加或订单删除的项目并增加了发货信息描述这些变化可以被处理使用的事件来更新物化视图

注意:

更多信息请参见物化视图模式



此外,在任何时间,可以应用程序来读取事件的历史并使用它通过有效地“回放消耗所有有关该实体事件,以实现一个实体的当前状态。这可能发生在需求,以处理的要求或通过计划任务,使实体的状态可以被保存为一个物化视图,以支持表示层实现域对象

图1示出图案的逻辑的概述,包括一些使用事件,例如,创建的物化视图与外部应用程序系统整合事件,重放事件来创建特定实体的当前状态突起的选项。

图1  - 的情况下获取模式的概述和示例


事件获取模式提供了许多优点,包括如下
•活动是不可变的,因此可以使用仅追加操作来保存用户界面,工作流或过程发起产生该事件可以继续并且处理这些事件可以在后台运行的任务的操作。,结合的事实,记录的执行过程中没有争用,可以极大地提高性能和可扩展性的应用,尤其是对于表示层用户界面。
•活动是描述所发生的一些动作,再加上描述事件所代表的行动所需的任何相关数据的简单对象。事件不直接更新数据存储;它们被简单地记录用于处理在适当的时间这些因素可以简化实施和管理。
•活动通常意味着一个领域的专家对象关系的阻抗失配的复杂性可能意味着一个数据库表可能无法清楚地了解领域的专家表是表示系统中,发生的事件的当前状态,人工构建体。
•事件的采购可以帮助防止引起冲突,因为它避免了要求直接更新在数据存储对象的并发更新。然而,领域模型仍然必须用来保护自己免受可能导致不一致的状态的请求
事件的仅追加存储提供了可用于监测对一个数据存储所采取的行动的审核跟踪​​再生的当前状态作为通过重播事件随时物化视图预测,协助测试调试系统此外,该规定使用补偿事件取消变化提供了被逆转的变化,这不会是如果模型简单地存储在当前状态的情况下的历史记录。事件列表中,也可以用于分析应用程序的性能,并检测用户行为趋势,获得其它有用的商业信息。
响应进行操作事件存储提出的每个事件的任何任务事件解耦提供了灵活性和可扩展性例如用于处理所述事件存储引发的事件任务都知道只有事件的性质和包含的数据。时所执行的任务的方式是从触发事件的动作去耦。此外多个任务可以处理每个事件这可能使得与其他服务和系统,只需要监听事件存储提出了新的事件,易于集成然而,该事件采购事件往往是非常低的水平,并且可能有必要以产生特异性整合事件来代替。


注意:

事件来源通常结合CQRS模式通过执行数据管理任务响应于所述事件,通过物化从所存储的事件的意见。

问题和注意事项


在决定如何实现这个模式时,请考虑以下几点
创建物化视图重放事件产生的数据预测时,系统只会是最终一致有一个应用程序添加事件,事件存储作为处理一个请求的结果之间有一些延迟公布事件,而消费者事件的处理它们在此期间,描述该进一步修改实体的的事件可能已到达的情况下存储。


注意

请参阅数据一致性底漆有关最终一致性的信息


事件存储是信息不可变源,因此事件数据不应该被更新。撤销变更更新一个实体唯一办法是补偿的事件添加到事件存储就像你会用负数交易会计核算。如果持久化事件的格式而不是数据需要改变,或者在迁移过程中可能难以对现有的事件结合在商店新版本。可能有必要通过所有更改的事件来循环以使它们符合新格式添加使用该格式的新事件。考虑使用上的每个版本的事件模式的版本标记,以保持旧的和新的事件格式。
•多线程应用程序和应用程序的多个实例可以被存储在事件存储事件。事件存储事件的一致性非常重要的,影响到特定实体的顺序改变为一个实体发生影响其当前状态)的事件的顺序添加时间戳每一个事件一个选项,可以帮助避免出现问题另一种常见的做法是将注释每一个事件所导致使用增量标识符的请求如果两个动作试图同一实体的同时添加的事件,该事件存储可以拒绝匹配现有实体标识符和事件标识符事件
有没有标准的方法,还是准备机制,如SQL查询读取事件来获取信息。可以提取的唯一数据使用事件标识符作为条件的事件流。事件ID通常映射单个实体。一个实体的当前状态,可以通过重放所有涉及针对该实体的原始状态的事件确定。
每个事件的长度可以管理并更新该系统的后果。如果很大,可以考虑创建以特定的间隔的快照,如活动指定数量可以该快照,通过重放该时间点之后发生的任何事件中得到的实体的当前状态

注意:

有关创建数据快照的更多信息,请参见Martin Fowler的企业应用架构的网站和主从快照复制MSDN上的快照


尽管采购活动减少冲突的更新数据的机会应用程序必须仍然能够应付可能出现的通过最终一致性和缺乏交易不一致例如,一个事件,指示库存的库存的减少可能在数据存储到达,而对于产品的订单被放置,从而导致需求调和这两种业务;可能是建议客户或创建后顺序
•事件发布可能是“至少一次”等消费者事件,必须幂等它们不能重新一个事件描述,如果该事件被处理多于一次更新例如,如果消费者的多个实例保持一些实体的一个属性的集合,如订单放置的总数中,只有一个必须一个“顺序放置事件发生时,递增该聚合成功。虽然这不是事件来源的固有特性是通常的实现决策。

使用这个模式


这种模式非常适合以下情况:
当你想捕捉意图”,“目的”或“理”中的数据。例如,已关闭帐户,或已故变为一个客户实体可被捕捉为一系列特定的事件类型
当它是至关重要的,尽量减少完全避免更新冲突的发生数据
•当你想记录发生的事件并能够重放它们来恢复系统的状态;用它们来回滚更改的系统;或者简单地作为一个历史审计日志。例如,当一个任务涉及多个步骤,您可能需要执行恢复更新操作,然后重放一些步骤,使数据恢复到一致状态
当使用事件应用程序的动作的自然特征并且需要很少的额外的开发或实现工作
当您需要输入分离应用这些行动所需的任务更新数据的过程可能是为了提高用户界面的性能,分发事件其它听众其他应用程序或服务,必须采取某些行动的事件发生一个例子是费用提交网站整合了工资制度,使响应费用提交网站数据的更新提出的事件存储事件由两个网站和工资系统消耗
当您想要的灵活性,能够改变实体化模型和实体数据格式,如果需求发生变化或者当结合使用CQRS需要适应的读模式公开数据的意见。
CQRS一起使用最终一致性是可以接受的,而读出的模型被更新,或者,从事件流中再水化的实体和数据发生的性能的影响是可以接受的。

这种模式可能不适合下列情况
•小型或简单的领域很少或没有业务逻辑或者非域系统,自然与传统的CRUD的数据管理机制,运作良好的系统。
哪里的一致性和实时更新数据的意见是必需的系统
不要求系统中的审计跟踪,历史,功能,回滚和回放操作。
系统中只有非常低的冲突更新基础数据的发生。例如,主要为添加数据而不是更新它的系统。


例子


的会议管理系统需要跟踪会议完成了预定的数量,以便它可以检查是否有座位仍然可用时,一个潜在的与会者试图做一个新的预订该系统可以存储预定的总数至少两个方面的会议
该系统可以存储关于预约的总数作为数据库中的搁置预约信息的独立的实体的信息。作为预订制成取消订单,则系统可以增加或减少数量适当这种方法在理论上是简单的,但可引起可扩展性问题,如果有大量的与会者试图进行预订短时间内座位例如最后一天预约期间闭合,以便之前
该系统可以存储大约预订和取消如在事件存储举办的活动信息。然后,它可以计算出可用通过重播这些事件的席位数。这种方法可以更加扩展性由于事件不变性系统只需要能够从事件存储读取数据将数据追加到该事件存储。关于预订和取消事件信息不会被修改

图2显示了如何将会议管理系统座位子系统可能通过采购活动来实现

图2 - 使用事件来源获取关于座位预订信息,会议管理系统


行动预留两个座位顺序如下
1.用户界面发出命令,以预留座位有两个人参加。该命令是由一个单独的命令处理程序一块逻辑从用户界面分离,并负责张贴的命令处理请求)处理。
包含所有预订会议信息

2.一种聚集通过查询描述预订和取消的事件构成。该集合体被称为SeatAvailability并且被包含在暴露聚合查询和修改数据的方法的域模型

注意:
一些优化利用快照(这样就不需要查询和重放事件的完整列表,以获得聚集的当前状态维持聚合在存储器中的高速缓存副本来考虑。

3,命令处理程序调用域模型曝光,使保留的方法。
4. SeatAvailability骨料记录包含席位保留数量的事件。聚合应用事件接下来的时间,所有的预订将用来计算的座位有多少仍然存在。
5.系统追加新的事件事件存储的事件列表

如果一个用户希望取消一个座位系统遵循不同的是,命令处理程序发出,其生成一个座位取消事件,并将其追加到事件存储区中的命令类似的过程

以及可扩展性提供更大的空间使用事件店内还提供了一个完整的历史审计追踪,预订和取消会议记录在事件存储事件真相权威唯一来源。没有必要持续聚集体的任何其他方法,因为该系统可以很容易地重放这些事件和恢复状态,以任意的时间点。

注意:

您可以找到有关这个例子中,在本章中的模式与实践指导CQRS之旅MSDN上引入获取事件的更多信息

本文翻译自MSDN:http://msdn.microsoft.com/en-us/library/dn589792.aspx

目录
相关文章
|
26天前
|
设计模式 前端开发 搜索推荐
前端必须掌握的设计模式——模板模式
模板模式(Template Pattern)是一种行为型设计模式,父类定义固定流程和步骤顺序,子类通过继承并重写特定方法实现具体步骤。适用于具有固定结构或流程的场景,如组装汽车、包装礼物等。举例来说,公司年会节目征集时,蜘蛛侠定义了歌曲的四个步骤:前奏、主歌、副歌、结尾。金刚狼和绿巨人根据此模板设计各自的表演内容。通过抽象类定义通用逻辑,子类实现个性化行为,从而减少重复代码。模板模式还支持钩子方法,允许跳过某些步骤,增加灵活性。
|
2月前
|
设计模式 安全 Java
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
|
1天前
|
设计模式
「全网最细 + 实战源码案例」设计模式——模式扩展(配置工厂)
该设计通过配置文件和反射机制动态选择具体工厂,减少硬编码依赖,提升系统灵活性和扩展性。配置文件解耦、反射创建对象,新增产品族无需修改客户端代码。示例中,`CoffeeFactory`类加载配置文件并使用反射生成咖啡对象,客户端调用时只需指定名称即可获取对应产品实例。
57 40
|
2天前
|
设计模式 关系型数据库
「全网最细 + 实战源码案例」设计模式——简单工厂模式
简单工厂模式是一种创建型设计模式,通过工厂类根据传入参数创建不同类型的对象,也称“静态工厂方法”模式。其结构包括工厂类、产品接口和具体产品类。优点是封装性强、代码复用性好;缺点是扩展性差,增加新产品时需修改工厂类代码,违反开闭原则。适用于对象种类较少且调用者无需关心创建细节的场景。
35 19
|
2天前
|
设计模式 关系型数据库
「全网最细 + 实战源码案例」设计模式——工厂方法模式
简单工厂模式是一种创建型设计模式,通过一个工厂类根据传入参数创建不同类型的产品对象,也称“静态工厂方法”模式。其结构包括工厂类、产品接口和具体产品类。适用于创建对象种类较少且调用者无需关心创建细节的场景。优点是封装性强、代码复用性好;缺点是扩展性差,增加新产品时需修改工厂类代码,违反开闭原则。
29 15
|
4月前
|
设计模式 数据库连接 PHP
PHP中的设计模式:提升代码的可维护性与扩展性在软件开发过程中,设计模式是开发者们经常用到的工具之一。它们提供了经过验证的解决方案,可以帮助我们解决常见的软件设计问题。本文将介绍PHP中常用的设计模式,以及如何利用这些模式来提高代码的可维护性和扩展性。我们将从基础的设计模式入手,逐步深入到更复杂的应用场景。通过实际案例分析,读者可以更好地理解如何在PHP开发中应用这些设计模式,从而写出更加高效、灵活和易于维护的代码。
本文探讨了PHP中常用的设计模式及其在实际项目中的应用。内容涵盖设计模式的基本概念、分类和具体使用场景,重点介绍了单例模式、工厂模式和观察者模式等常见模式。通过具体的代码示例,展示了如何在PHP项目中有效利用设计模式来提升代码的可维护性和扩展性。文章还讨论了设计模式的选择原则和注意事项,帮助开发者在不同情境下做出最佳决策。
|
5月前
|
存储 安全 JavaScript
云计算浪潮中的网络安全之舵探索Node.js中的异步编程模式
【8月更文挑战第27天】在数字化时代的风帆下,云计算如同一片广阔的海洋,承载着企业与个人的数据梦想。然而,这片海洋并非总是风平浪静。随着网络攻击的波涛汹涌,如何确保航行的安全成为了每一个船员必须面对的挑战。本文将探索云计算环境下的网络安全策略,从云服务的本质出发,深入信息安全的核心,揭示如何在云海中找到安全的灯塔。
|
2月前
|
设计模式 开发者 Python
Python编程中的设计模式:工厂方法模式###
本文深入浅出地探讨了Python编程中的一种重要设计模式——工厂方法模式。通过具体案例和代码示例,我们将了解工厂方法模式的定义、应用场景、实现步骤以及其优势与潜在缺点。无论你是Python新手还是有经验的开发者,都能从本文中获得关于如何在实际项目中有效应用工厂方法模式的启发。 ###
|
2月前
|
人工智能 边缘计算 云计算
2024.11|云计算行业的商业模式创新方法及实践
截至2024年,全球云计算行业迈入全新阶段,从IaaS到大规模AI模型平台,技术与商业模式不断创新。本文分析全球最新技术进展,探讨云计算商业模式创新策略与实践,解析云服务厂商如何通过技术革新实现价值最大化,推动企业数字化与智能化转型。重点讨论AI与云计算的深度融合、边缘计算与去中心化发展、平台化与生态系统建设,以及数据安全与绿色云计算等关键议题。
156 30
|
2月前
|
设计模式 消息中间件 搜索推荐
Java 设计模式——观察者模式:从优衣库不使用新疆棉事件看系统的动态响应
【11月更文挑战第17天】观察者模式是一种行为设计模式,定义了一对多的依赖关系,使多个观察者对象能直接监听并响应某一主题对象的状态变化。本文介绍了观察者模式的基本概念、商业系统中的应用实例,如优衣库事件中各相关方的动态响应,以及模式的优势和实际系统设计中的应用建议,包括事件驱动架构和消息队列的使用。

热门文章

最新文章