- 当数据库发生更改时,主动发送领域事件(Domain Event)通知Elasticsearch进行更新,可以参考《COLA 4.x架构入门和项目实践》技术专栏中的领域事件入门实践部分的内容。
- 直接监听MySQL的binlog更新Elasticsearch。关于Elasticsearch的详细使用,可以参考《Elasticsearch 7.x从入门到精通》技术专栏。
领域驱动设计DDD和CQRS架构模式落地实践
在领域驱动架构中,通常会将查询和命令操作分开,我们称之为CQRS(命令查询职责分离Command Query Responsibility Segregation)。这张图是来自Martin Fowler大师的文章CQRS(https://www.martinfowler.com/bliki/CQRS.html)。
上图中读模块Query Model和写模块Command Model只是逻辑分离,物理层面还是使用了同一个数据库。我们可以进一步将数据库改成读库和写库做到物理分离,这时候就需要同步读写库。
如果数据量不大,可以采用简单的处理方式,物理层面还是使用一个数据库,查询的时候部分数据直接从数据库读取,部分数据使用到了Elasticsearch,数据同步可以采用两种方案: