Traditionally, MySQL has been used to power most of the backend services at Bolt. We’ve designed our schemas in a way that they’re sharded into different MySQL clusters. Each MySQL cluster contains a subset of data and consists of one primary and multiple replication nodes.
Once data is persisted to the database, we use the Debezium MySQL Connector to capture data change events and send them to Kafka. This gives us an easy and reliable way to communicate changes between back-end microservices.
Bolt has grown considerably over the past few years, and so did the volume of data written to…
Senior Software Engineer at Bolt. Focusing on Kafka, Debezium, Change Data Capture, data warehousing, and building event-driven systems. Twitter: @keweishang