Member-only story
Event Sourcing: why using a message broker is a bad idea
I’ve seen many implementations of Event Sourcing that use a message broker to publish events to the read models. I’ve used that pattern and contributed to ES “frameworks” that implement that pattern. I think It is a bad idea. I’ll explain why:
1) Writing to the event store AND publishing events to a broker needs to be atomic. In most cases a distributed transaction using two phase commits is not an option. We need to create some mechanism to deal with faulty connections between publisher and broker:
data:image/s3,"s3://crabby-images/6b38d/6b38d0774b52374ed12f4a28b5bb2e8e7c9ed6aa" alt=""
To reliably/atomically update the event store and publish events to the broker, we can use the Transactional Outbox Pattern:
data:image/s3,"s3://crabby-images/d6543/d654329bb8893e7739bc49826f5f16211b9205ed" alt=""
The outbox pattern uses a message relay process to publishes the events inserted…