Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/apecloud/ape-dts
Ape Data Transfer Suite, written in Rust. Provides ultra-fast data replication between MySQL, PostgreSQL, Redis, MongoDB, Kafka and ClickHouse, ideal for disaster recovery (DR) and migration scenarios.
https://github.com/apecloud/ape-dts
binlog cdc clickhouse data-migration data-transfer etl kafka-connect mongo mysql postgres redis starrocks
Last synced: 7 days ago
JSON representation
Ape Data Transfer Suite, written in Rust. Provides ultra-fast data replication between MySQL, PostgreSQL, Redis, MongoDB, Kafka and ClickHouse, ideal for disaster recovery (DR) and migration scenarios.
- Host: GitHub
- URL: https://github.com/apecloud/ape-dts
- Owner: apecloud
- License: agpl-3.0
- Created: 2023-01-12T04:16:22.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-12-26T08:58:15.000Z (18 days ago)
- Last Synced: 2024-12-28T19:02:52.313Z (16 days ago)
- Topics: binlog, cdc, clickhouse, data-migration, data-transfer, etl, kafka-connect, mongo, mysql, postgres, redis, starrocks
- Language: Rust
- Homepage:
- Size: 63.5 MB
- Stars: 262
- Watchers: 6
- Forks: 29
- Open Issues: 38
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-clickhouse - apecloud/ape-dts - Ape Data Transfer Suite is a Rust-based tool enabling ultra-fast data replication between various databases ideal for migration and disaster recovery. (Integrations / ETL and Data Processing)
README
# English | [中文](README_ZH.md)
# Introduction
- ape-dts is a data migration tool enabling any-to-any data transfers.
- It also provides data subscription and data processing.
- It is lightweight, efficient and standalone, requiring no third-party components or extra storage.
- In Rust.## Key features
- Supports data migration between various databases, both homogeneous and heterogeneous.
- Supports snapshot and cdc tasks with resume from breakpoint.
- Supports checking and revising data.
- Supports filtering and routing at the database, table, and column levels.
- Implements different parallel algorithms for different sources, targets, and task types to improve performance.
- Allows loading user-defined Lua scripts to modify the data.
- Supports starting ape-dts as an HTTP server to pull data from the source, allowing users to use any language's HTTP client to retrieve and consume the data.## Supported task types
| | mysql -> mysql | pg -> pg | mongo -> mongo | redis -> redis | mysql -> kafka | pg -> kafka| mysql -> starrocks | mysql -> clickhouse | mysql -> tidb | pg -> starrocks |
| :-------- | :-------- | :-------- | :-------- | :-------- | :-------- | :-------- | :-------- | :-------- | :-------- | :-------- |
| Snapshot | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ |
| CDC | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ |
| Data check/revise/review | ✔ | ✔ | ✔ | | | | | | ✔ | |
| Structure migration | ✔ | ✔ | | | | | ✔ | ✔ | ✔ | ✔ |# Quick starts
## Tutorial
- [prerequisites](./docs/en/tutorial/prerequisites.md)
- [mysql -> mysql](./docs/en/tutorial/mysql_to_mysql.md)
- [pg -> pg](./docs/en/tutorial/pg_to_pg.md)
- [mongo -> mongo](./docs/en/tutorial/mongo_to_mongo.md)
- [redis -> redis](./docs/en/tutorial/redis_to_redis.md)
- [mysql -> starrocks](./docs/en/tutorial/mysql_to_starrocks.md)
- [mysql -> clickhouse](./docs/en/tutorial/mysql_to_clickhouse.md)
- [mysql -> tidb](./docs/en/tutorial/mysql_to_tidb.md)
- [mysql -> kafka -> consumer](./docs/en/tutorial/mysql_to_kafka_consumer.md)
- [pg -> starrocks](./docs/en/tutorial/pg_to_starrocks.md)
- [pg -> kafka -> consumer](./docs/en/tutorial/pg_to_kafka_consumer.md)
- [mysql -> ape_dts(HTTP server) -> consumer](./docs/en/tutorial/mysql_to_http_server_consumer.md)
- [pg -> ape_dts(HTTP server) -> consumer](./docs/en/tutorial/pg_to_http_server_consumer.md)
- [snapshot + cdc without data loss](./docs/en/tutorial/snapshot_and_cdc_without_data_loss.md)
- [modify data by lua](./docs/en/tutorial/etl_by_lua.md)## Run tests
Refer to [test docs](./dt-tests/README.md) for details.
# More docs
- Configurations
- [config details](./docs/en/config.md)
- Structure tasks
- [migration](./docs/en/structure/migration.md)
- [check](./docs/en/structure/check.md)
- [check by Liquibase](./docs/en/structure/check_by_liquibase.md)
- Snapshot tasks
- [data migration](./docs/en/snapshot/migration.md)
- [data check](./docs/en/snapshot/check.md)
- [data revise](./docs/en/snapshot/revise.md)
- [data review](./docs/en/snapshot/review.md)
- [resume at breakpoint](./docs/en/snapshot/resume.md)
- CDC tasks
- [data sync](./docs/en/cdc/sync.md)
- [heartbeat to source database](./docs/en/cdc/heartbeat.md)
- [two-way data sync](./docs/en/cdc/two_way.md)
- [generate sqls from CDC](./docs/en/cdc/to_sql.md)
- [resume at breakpoint](./docs/en/cdc/resume.md)
- Custom consumers
- [mysql/pg -> kafka -> consumer](./docs/en/consumer/kafka_consumer.md)
- [mysql/pg -> ape_dts(HTTP server) -> consumer](./docs/en/consumer/http_consumer.md)
- Data processing
- [modify data by lua](./docs/en/etl/lua.md)
- Monitor
- [monitor info](./docs/en/monitor/monitor.md)
- [position info](./docs/en/monitor/position.md)
- Task templates
- [mysql -> mysql](./docs/templates/mysql_to_mysql.md)
- [pg -> pg](./docs/templates/pg_to_pg.md)
- [mongo -> mongo](./docs/templates/mongo_to_mongo.md)
- [redis -> redis](./docs/templates/redis_to_redis.md)
- [mysql/pg -> kafka](./docs/templates/rdb_to_kafka.md)
- [mysql/pg -> ape_dts(HTTP server)](./docs/templates/rdb_to_http_server.md)
- [mysql -> starrocks](./docs/templates/mysql_to_starrocks.md)
- [mysql -> clickhouse](./docs/templates/mysql_to_clickhouse.md)
- [pg -> starrocks](./docs/templates/pg_to_starrocks.md)# Benchmark
- MySQL -> MySQL, Snapshot| Method | Node Specs | RPS(rows per second) | Source MySQL Load (CPU/Memory) | Target MySQL Load (CPU/Memory) |
| :-------- | :-------- | :-------- | :-------- | :-------- |
| ape_dts | 1c2g | 71428 | 8.2% / 5.2% | 211% / 5.1% |
| ape_dts | 2c4g | 99403 | 14.0% / 5.2% | 359% / 5.1% |
| ape_dts | 4c8g | 126582 | 13.8% / 5.2% | 552% / 5.1% |
| debezium | 4c8g | 4051 | 21.5% / 5.2% | 51.2% / 5.1% |- MySQL -> MySQL, CDC
| Method | Node Specs | RPS(rows per second) | Source MySQL Load (CPU/Memory) | Target MySQL Load (CPU/Memory) |
| :-------- | :-------- | :-------- | :-------- | :-------- |
| ape_dts | 1c2g | 15002 | 18.8% / 5.2% | 467% / 6.5% |
| ape_dts | 2c4g | 24692 | 18.1% / 5.2% | 687% / 6.5% |
| ape_dts | 4c8g | 26287 | 18.2% / 5.2% | 685% / 6.5% |
| debezium | 4c8g | 2951 | 20.4% / 5.2% | 98% / 6.5% |- Image size
| ape_dts:2.0.14 | debezium/connect:2.7 |
| :-------- | :-------- |
| 86.4 MB | 1.38 GB |- more benchmark [details](./docs/en/benchmark.md)
# Contributing
## Structure
![Structure](docs/img/structure.png)
## Modules
- dt-main: program entry
- dt-connector: extractors + sinkers for databases
- dt-pipeline: pipeline to connect extractors and sinkers
- dt-parallelizer: parallel algorithms
- dt-task: create extractors + sinkers + pipelines + parallelizers according to configurations
- dt-common: common utils, basic data structures, metadata management
- dt-tests: integration tests- related sub module: [mysql binlog connector in rust](https://github.com/apecloud/mysql-binlog-connector-rust)
## Build
- cargo build
- [build images](./docs/en/build_images.md)## Checklist
- run `cargo clippy --all-targets --all-features --workspace` fix all clippy issues.# Contact us
[Slack Community](https://join.slack.com/t/kubeblocks/shared_invite/zt-22cx2f84x-BPZvnLRqBOGdZ_XSjELh4Q)
Wechat Group