AI 年度盘点与2025发展趋势展望,50+案例解析亮相AICon 了解详情
写点什么

构建事件溯源系统时犯的错误和恢复措施

  • 2019-07-17
  • 本文字数:1303 字

    阅读完需:约 4 分钟

构建事件溯源系统时犯的错误和恢复措施

Nat Pryce和他的团队开始构建基于事件溯源架构的新系统时,在设计上犯了几个重大的错误,但最后成功地修复了这些错误,修复过程也并不复杂。在一篇博文中,Pryce 详细描述了他们所犯的错误以及促使他们重构架构并从错误中恢复的因素。


他们犯的第一个错误是,将事件历史和对应实体的当前状态视图一起持久化。当前状态不是由于事件更新而产生的投影,而是由记录事件的命令处理程序来更新的。这就引入了两个问题:一是无法通过记录的事件重建实体的状态;二是在将关系模型中管理方式移植过来管理当前状态,开销也十分巨大。


Pryce(《测试驱动的面向对象软件开发》一书的合著者)承认同时使用这两种持久化机制,在某种程度上忽略了事件溯源的整体要点。造成这个错误的原因是,他们提出这个设计为了让团队满意,而没有反思与事件溯源文献中的建议不符之处。他们按照这个设计一直推进到困难明显超过了优势时才反思。随后,通过技术回顾,他们同意转向规范的事件溯源设计。


他们犯的第二个错误是,混淆了事件驱动架构和事件溯源架构。在事件驱动架构中,组件执行任务以响应接收到的事件,并且发出事件来通知状态的变更。在事件溯源架构中,状态变更被当作事件来记录,并且实体的当前状态是根据与实体相关的所有事件计算得出的。对两者的混淆导致产生了这样的设计:对于一个组件来说,既记录了它历史上的所有事件,它又触发了其他组件中的活动。当他们必须在事件中实现相应逻辑以区分,a)读取事件并对其作出反应,和 b)读取事件以了解其历史事件时,他们才意识到了这个错误。


这种混淆也导致了他们将事件存储用作消息总线的设计。消息总线需要发出通知,使组件能够保存最新的投影,这意味着他们使用事件存储来记录事件历史和组件之间的瞬态通信。这使得他们在使用事件存储前,必须从历史中过滤掉的技术事件。


Pryce 描述的最后一个错误是,使用 HTTP 接口在事件存储中读取和存储事件。这阻碍了团队使用ACID事务处理事件,从而迫使他们不得不构建其他机制来试图缓解事务处理的情况。


幸运的是,在线上系统的事件历史受到影响之前,他们早就发现了所有错误。 HTTP 接口已替换成命令处理器的直接数据库连接。他们停止了使用消息通知,转而使用 REST 在组件之间传递数据 。最后,他们去除了命令处理程序中对实体的当前状态的更新逻辑。相反,状态是在加载实体时根据事件历史计算的。他们仍然使用事件当前状态的投影,但这纯粹是为了优化,作为一个直读缓存使用。


Pryce 最后指出,尽管他们对架构进行了重大变更,但这些变更很简单,并且他指出这样做的原因与事件溯源是正交的。


他们的应用程序采用了端口和适配器架构(六边形架构),采用这种架构很容易变更隐藏在端口或适配器接口背后的具体实现。利用端口和适配器架构,还可以编写大量的功能测试。采用该架构,可以实现技术架构与功能实现的分离,这样,技术架构变更时就简单多了。


如 Pryce 所说,当你在系统中采用一种不熟悉的架构风格时,不可避免地会犯错误。他认为,端口与适配器风格不仅允许他们在缺乏经验的情况下采用事件溯源架构,但也可以让他们在构建系统时的误解中恢复过来。


原文链接:


Mistakes and Recoveries When Building an Event Sourcing System


2019-07-17 08:003864
用户头像

发布了 302 篇内容, 共 198.1 次阅读, 收获喜欢 599 次。

关注

评论

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

敏捷开发最佳实践:质量维度实践案例之软硬一体持续交付

爱吃小舅的鱼

敏捷 敏捷开发 敏捷质量管理

Scrumban的实施指南

爱吃小舅的鱼

敏捷 敏捷开发 Scrumban

国内行业桌面云解决方案哪家比较强?

青椒云云电脑

桌面云 云桌面 云桌面方案

Sora,数据驱动的物理引擎

澳鹏Appen

人工智能 生成式AI sora 文生视频 视频标注

英特尔锐炫新旧驱动对比测评:新老游戏全方位进化!

E科讯

从 0 到 1 搭建亿级商品 ES 搜索引擎

字节跳动云原生计算

云原生 ES 云搜索

拼多多API助力商家提升销售效果和市场竞争力

技术冰糖葫芦

API 接口

测试开发名企定向培养训练营,快速提升核心竞争力!

霍格沃兹测试开发学社

如何利用Allure报告提升你的测试效率?

霍格沃兹测试开发学社

2024-02-28:用go语言,有一个由x轴和y轴组成的坐标系, “y下“和“y上“表示一条无限延伸的道路,“y下“表示这个道路的下限,“y上“表示这个道路的上限, 给定一批长方形,每一个长方形有(

福大大架构师每日一题

福大大架构师每日一题

Java面试题大全(2024最新版)1000+大厂面试题附答案详解

架构师之道

程序员 java面试

SD-WAN助力企业数据传输安全

Ogcloud

SD-WAN 企业网络 SD-WAN组网 SD-WAN服务商 SDWAN

WiMinet 评说1.3:模拟式UDP中继技术缺陷

Geek_ab1536

《App备案入门指南》:拯救备案小白,让您不再担心

雪奈椰子

SD-WAN对金融行业的重要性

Ogcloud

SD-WAN 企业网络 SD-WAN组网 SD-WAN服务商 SDWAN

超越传统:人工智能赋能加持下的自动化测试

霍格沃兹测试开发学社

如何生成速卖通平台的API密钥?

技术冰糖葫芦

API 接口

欢迎参与2024年 OpenTiny 开源项目用户调研

OpenTiny社区

开源 前端 低代码 组件库

“课-训-赛”育人才!南开大学闫晓玉老师分享Python实战类课程的教学经历

ModelWhale

Python 人才培养 数据科学 教学

商品评价聚合:利用API从多个来源获取数据的详细指南

Noah

一次投入,多倍回报,英特尔vPro驱动全新商用AI PC

E科讯

如何创建自己的Spring Boot Starter并为其编写单元测试

EquatorCoco

Spring Boot 开发测试 功能测试

WiMinet 评说1.2:多跳无线网络的困境

Geek_ab1536

探秘闲鱼商品详情关键词搜索电商API接口,让你轻松找到心仪的宝贝!

联讯数据

HFT算力合约模式系统开发丨技术详情开发

l8l259l3365

揭秘「 B 站最火的 RAG 应用」是如何炼成的

Zilliz

AI Milvus Zilliz LLM rag

面试官:说一下红锁RedLock的实现原理?

EquatorCoco

程序员 面试 红锁

MES系统中的手动排产和自动排产-助力生产效率

万界星空科技

制造业 mes 万界星空科技 生产管理 自动排班

WiMinet 评说1.1:多跳无线网络的现状

Geek_ab1536

深入解析Python并发编程的多线程和异步编程

不在线第一只蜗牛

Python 多线程 代码 并发

为什么您的网站需要美国主机CDN加速?一文解答所有疑问

一只扑棱蛾子

美国主机

构建事件溯源系统时犯的错误和恢复措施_语言 & 开发_Jan Stenberg_InfoQ精选文章