共计 654 个字符,预计需要花费 2 分钟才能阅读完成。
本文转载自【何以解耦】:https://codedecoupled.com/php…
在事件溯源架构中,通过事件流获取利用的以后状态可能造成性能问题,Projector(放映机)通过监听事件,生成独立的视图保留利用的以后状态。咱们能够将其设想成数据库中的物化视图,或者是一种缓存。
以下是从咱们的实战经验中总结出的几种 Projector 用例。
实战用例
查问模型
用户对页面的反应速度要求较高,咱们能够应用 Projector 生成服务于用户的查问模型。
值得一提的是 Projector 可应用与事件流不同的数据长久化形式,比方事件流本来贮存在 MySQL, Projector 可应用 ElastiSearch 长久化查问模型:
让咱们看一个简略的案例,应用 Projector 生成订单查问模型:
反对业务实现
当其余客户须要及时获取利用的以后状态,然而无奈通过简略的事件传送时,咱们能够应用 Projector 生成相似于缓冲的 Repository。此 Repository 将为实现业务逻辑提供及时的利用状态。
让咱们看一个简略的案例,应用 Projector 生成车辆可预约 Repository:
值得注意的是,这种用例偏向于同步解决计划,因为其时效性个别比拟大。
总结
Projector 是一个简略且弱小的模式,Projector 的职责繁多且专一,易于编写单元测试。
本文转载自【何以解耦】:https://codedecoupled.com/php…,如果你也对 TDD,DDD 以及简洁代码感兴趣,欢送关注公众号【何以解耦】,一起摸索软件开发之道。
正文完