什么是CQRS模式?
CQRS是Command and Query Responsibility Segregation的缩写,直译就是命令与查询责任分离的意思。
- 命令会改变对象的状态,但不返回任何数据。
- 查询会返回数据,但并不改变对象的状态。
如果将查询和命令简化理解成对数据的读写操作,CQRS模式的含义就是,应用架构中负责模型读写的模块应当分离。
这里的分离,不单是程序代码或逻辑上的分离,也包括数据模型,甚至是数据存储的分离。
好处:
- 对于领域模型十分复杂的场景,CQRS模式可以增强架构的扩展性和灵活性,同时降低模块的复杂度。
- 由于读和写的模型分离,可以分别针对读写操作优化,同时避免的数据锁定,对于性能提升也有帮助。
局限:
- CQRS并不是一种易于实现的模式。因为读写责任的分离,它不如CRUD来的直观。
- 读写数据同步和确保数据一致性会是一个问题。
什么是Event Sourcing模式?
Event Sourcing (ES)模式是一个关于如何存储domain model状态的模式。
这个模式不直接存储模型的状态,而是存储模型状态变化的历史。应用想要获取模型的当前状态时,需要重演整个历史来得到当前状态。
好处:
- 简化写操作,所有Event一旦发生,就变为immutable,写操作就变为简单的添加纪录,避免了复杂的锁定和冲突。
- ES模式保留了所有状态的历史,容易做audit,或纠错。
局限:
- 随着历史数据的增加,查询操作的性能可能会降低。
组合使用?
参考阅读
什么是事件溯源?https://www.cnblogs.com/netfocus/archive/2012/02/12/2347911.html
深入浅出Event Sourcing和CQRS http://www.imooc.com/article/40858
CQRS和Event Sourcing模式 https://chunliu.me/2018/07/20/cqrs%E5%92%8Cevent-sourcing%E6%A8%A1%E5%BC%8F/
CQRS + Event Sourcing – Step by Step https://danielwhittaker.me/2020/02/20/cqrs-step-step-guide-flow-typical-application/