Skip to main content

Tool for replication of MySQL databases to ClickHouse

Project description

mysql_ch_replicator

mysql_ch_replicator is a powerful and efficient tool designed for real-time replication of MySQL databases to ClickHouse.

With a focus on high performance, it utilizes batching heavily and uses C++ extension for faster execution. This tool ensures seamless data integration with support for migrations, schema changes, and correct data management.

Features

  • Real-Time Replication: Keeps your ClickHouse database in sync with MySQL in real-time.
  • High Performance: Utilizes batching and ports slow parts to C++ (e.g., MySQL internal JSON parsing) for optimal performance.
  • Supports Migrations/Schema Changes: Handles adding, altering, and removing tables without breaking the replication process.
  • Recovery without Downtime: Allows for preserving old data while performing initial replication, ensuring continuous operation.
  • Correct Data Removal: Unlike MaterializedMySQL, mysql_ch_replicator ensures physical removal of data.
  • Comprehensive Data Type Support: Accurately replicates most data types, including JSON, booleans, and more. Easily extensible for additional data types.
  • Multi-Database Handling: Replicates the binary log once for all databases, optimizing the process compared to MaterializedMySQL, which replicates the log separately for each database.

Installation

To install mysql_ch_replicator, use the following command:

pip install mysql_ch_replicator

You may need to also compile C++ components if they're not pre-built for your platform.

Usage

Basic Usage

To start the replication process:

  1. Prepare config file. Use example_config.yaml as an example.
  2. Start the replication:
mysql_ch_replicator --config config.yaml run_all

Configuration

mysql_ch_replicator can be configured through a configuration file. Here is the config example:

mysql:
  host: 'localhost'
  port: 8306
  user: 'root'
  password: 'root'

clickhouse:
  host: 'localhost'
  port: 8323
  user: 'default'
  password: 'default'

binlog_replicator:
  data_dir: '/home/user/binlog/'
  records_per_file: 100000

databases: 'database_name_pattern_*'
  • mysql MySQL connection settings
  • clickhouse ClickHouse connection settings
  • binlog_replicator.data_dir Directory for store binary log and application state
  • databases Databases name pattern to replicate, eg db_* will match db_1 db_2 db_test

Advanced Features

Migrations & Schema Changes

mysql_ch_replicator supports the following:

  • Adding Tables: Automatically starts replicating data from newly added tables.
  • Altering Tables: Adjusts replication strategy based on schema changes.
  • Removing Tables: Handles removal of tables without disrupting the replication process.

Recovery Without Downtime

In case of a failure or during the initial replication, mysql_ch_replicator will preserve old data and continue syncing new data seamlessly. You could remove the state and restart replication from scratch.

Development

To contribute to mysql_ch_replicator, clone the repository and install the required dependencies:

git clone https://github.com/your-repo/mysql_ch_replicator.git
cd mysql_ch_replicator
pip install -r requirements.txt

Running Tests

For running test you will need:

  1. MySQL and ClickHouse server
  2. config.yaml that will be used during tests
  3. Run tests with:
pytest -v -s test_mysql_ch_replicator.py

Contribution

Contributions are welcome! Please open an issue or submit a pull request for any bugs or features you would like to add.

License

mysql_ch_replicator is licensed under the MIT License. See the LICENSE file for more details.

Acknowledgements

Thank you to all the contributors who have helped build and improve this tool.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mysql_ch_replicator-0.0.4.tar.gz (106.7 kB view details)

Uploaded Source

Built Distribution

mysql_ch_replicator-0.0.4-py3-none-any.whl (119.2 kB view details)

Uploaded Python 3

File details

Details for the file mysql_ch_replicator-0.0.4.tar.gz.

File metadata

  • Download URL: mysql_ch_replicator-0.0.4.tar.gz
  • Upload date:
  • Size: 106.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.10.13 Darwin/21.5.0

File hashes

Hashes for mysql_ch_replicator-0.0.4.tar.gz
Algorithm Hash digest
SHA256 1e9e4af47703ac54eee3e46d74224833b37a20a84f18dccbaca11f8d07ba950c
MD5 9412581de0e23219d53728fc474610b6
BLAKE2b-256 93a4d11669df8e7e9ebc24c08b6c7952d970384a077e1eca52dedd5157ecd93f

See more details on using hashes here.

File details

Details for the file mysql_ch_replicator-0.0.4-py3-none-any.whl.

File metadata

File hashes

Hashes for mysql_ch_replicator-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 a61e5e6ad1f410c4d0af83b818d66e1d5cb44b500ded1e22db089af7a5bd3f1a
MD5 45f69eb08aa8079b7141f57e40032e50
BLAKE2b-256 8e233f471ffaf7d442d6e1dce9ce7efea8359727424a2c2d2be22eb93b5ab0a6

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page