从入门到放弃 - 事件溯源

本文转载自【何以解耦】:https://codedecoupled.com/php...

在接触事件溯源之初,其截然不同的设计模式常会让初学者望而却步。这篇文章概括了几种导致初学者放弃继续学习事件溯源的误解。

查询速度太慢

既然应用的当前状态需要通过事件流来获取的话,事件溯源无法实现对查询速度要求高的搜索功能。

当我们需要实现类似搜索这种对速度要求比较高的功能时,事件溯源提供了相应的解决方案 Projector。Projector 通过监听事件,生成独立的视图保存应用的当前状态。我们可以将其想象成数据库中的物化视图,或者是一种缓存。

聚合性能问题

随着事件数量的线性增长,塑造聚合的时间也会线性增长至无限长。

聚合需读取事件流来重塑其当前状态,塑造的时间确实会随事件数量的增长而呈线性增长,为了解决这个问题,事件溯源提供了一种叫做 Snapshot 的解决方案。

Snapshot 的中文意思是快照,顾名思义,Snapshot 的原理是将聚合的最新状态持久化。这样的话,在重塑时聚合便不需要读取所有的事件,这将大大提高其性能。

陡峭的学习曲线

与 CRUD 这种存储当前状态的模式相比,事件溯源的学习曲线太陡峭了,不值一顾。

学习事件溯源,我们必须改变传统的 CRUD 思想,学会使用事件驱动的方式解决问题。这种新的编程方式可以解决很多使用 CRUD 比较棘手的问题。

当然,我们也需要辩证地看待事件溯源。切不可任何项目都使用事件溯源,一定要分析业务场景,选择最理想的解决方案。

总结

放弃很简单,但坚持下来,一定很酷。

本文转载自【何以解耦】:https://codedecoupled.com/php...,如果你也对 TDD,DDD以及简洁代码感兴趣,欢迎关注公众号【何以解耦】,一起探索软件开发之道。

你可能感兴趣的:(后端php)