Skip to content

Commit

Permalink
Merge pull request #2334 from dolthub/fulghum/minor-doc-updates
Browse files Browse the repository at this point in the history
Updating reference for Dolt-to-MySQL replication
  • Loading branch information
fulghum authored Sep 10, 2024
2 parents b8b2dba + 09c1049 commit bc25de8
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 5 deletions.
5 changes: 2 additions & 3 deletions packages/dolt/content/guides/binlog-replication.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,11 @@
title: MySQL to Dolt Replication (Preview)
---

Dolt binlog replication allows a Dolt SQL Server to consume binlog replication events from a MySQL or MariaDB source database. This is a convenient way to try out Dolt in an existing system – there is no need to migrate your database, just configure Dolt as a replica and as your data replicates to the Dolt server, it will build up a commit history. You can access all the data versioning features of Dolt from the Dolt replica to audit how your data has changed, recover deleted data, or view the state of your data at any point in time.
MySQL to Dolt replication allows a Dolt SQL Server to consume binlog replication events from a MySQL or MariaDB source database. This is a convenient way to try out Dolt in an existing system – there is no need to migrate your database, just configure Dolt as a replica and as your data replicates to the Dolt server, it will build up a commit history. You can access all the data versioning features of Dolt from the Dolt replica to audit how your data has changed, recover deleted data, or view the state of your data at any point in time.

![Binlog replication](../.gitbook/assets/dolt-binlog-replication.png)

If you're looking for to replicate data in the opposite direction (i.e. where the Dolt server is the primary and the MySQL server is the replica), check out [our blog post on Dolt to MySQL replication](https://www.dolthub.com/blog/2023-02-17-binlog-replication-preview).

## Requirements for MySQL Primary Server

Expand Down Expand Up @@ -84,8 +85,6 @@ Clear out replication source and filtering configuration: `RESET REPLICA ALL;`

**Syntax gaps** – Dolt aims for 100% compatibility with MySQL, but there are still some gaps in supported syntax that we're actively working on filling in. Overall, Dolt supports the **vast** majority of MySQL's syntax, although you may still find a statement that executes on the MySQL primary, but won't execute on the Dolt read-replica because of a syntax gap. Please [let us know](https://github.com/dolthub/dolt/issues/new) if you hit this so we can help find a temporary workaround and fill in the syntax gap for you.

**Replica mode only** – Dolt can only consume binlog events as a replica; it cannot act as a primary and produce binlog events.

**Replication channels** – only the default replication channel ("") is supported.

**Replica filters** – We currently support only the `REPLICATE_DO_TABLE` and `REPLICATE_IGNORE_TABLE` filtering options. These will filter the data in a table, but in the current implementation you will still see DDL statements for all tables applied, even if you have filtered out their data. For example, even if you have configured filtering to ignore table `db01.t1`, the `CREATE TABLE` statement for `db01.t1` will still be applied to the replica.
Expand Down
13 changes: 11 additions & 2 deletions packages/dolt/content/reference/sql/server/replication.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ title: Replication

# Replication

Dolt can [replicate data](../../../concepts/dolt/rdbms/replication.md) between two or more Dolt servers, or can be a read-replica for a MySQL server. This page describes the two supported replication modes between a Dolt primary server and Dolt replica servers. See the [MySQL to Dolt Replication guide](../../../guides/binlog-replication.md) for more information on setting up a Dolt server as a read-replica for a MySQL server.
Dolt can [replicate data](../../../concepts/dolt/rdbms/replication.md) between two or more Dolt servers, or between Dolt and a MySQL server. This page describes the two supported replication modes between a Dolt primary server and Dolt replica servers. See the [MySQL to Dolt Replication guide](../../../guides/binlog-replication.md) for more information on setting up a Dolt server as a read-replica for a MySQL server, and [our blog post on Dolt-to-MySQL replication](https://www.dolthub.com/blog/2023-02-17-binlog-replication-preview/) for instructions on running a MySQL server as a replica of a Dolt primary.

In **Remote-Based Replication**, Dolt uses a remote as a middleman to facilitate replication between the
primary and read replicas. In this mode, Dolt replication triggers on a [Dolt
Expand Down Expand Up @@ -506,7 +506,7 @@ In the configured example, if you run the first statement on `dolt-1.db` and
the second statement on `dolt-2.db`, you will have performed an oderly failover
from `dolt-1.db` to make `dolt-2.db` the new primary.

### Atomatic Role Transitions
### Automatic Role Transitions

It can happen that server instances learn about new role configuration from
their peers as they attempt to replicate writes or when they receive a
Expand Down Expand Up @@ -728,3 +728,12 @@ If you have an existing MySQL or MariaDB server, you can configure Dolt as a rea
consumes data changes from the primary server, it creates Dolt commits, giving you a read-replica with a
versioned history of your data changes. See the [MySQL to Dolt Replication guide](../../../guides/binlog-replication.md)
for more details on how to configure this.

# Dolt to MySQL Replication

If you want to run Dolt as your primary database server, you can still replicate a single branch to a MySQL database.
This is often useful for change data capture (CDC) or data warehouse use cases that require pulling data via
MySQL's replication protocol.
For example, you can [use Debezium to monitor changes in a Dolt database](https://www.dolthub.com/blog/2024-07-19-debezium-works-with-dolt/) for CDC use cases.
See our [blog post on Dolt-to-MySQL replication](https://www.dolthub.com/blog/2023-02-17-binlog-replication-preview/) for
more details on setting up Dolt to MySQL replication.

0 comments on commit bc25de8

Please sign in to comment.