-
Notifications
You must be signed in to change notification settings - Fork 706
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
5 changed files
with
99 additions
and
10 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,88 @@ | ||
--- | ||
outline: deep | ||
--- | ||
|
||
# Architecture and Performance Description | ||
|
||
## Architecture Diagram | ||
|
||
When both the source and destination are clusters, the synchronization architecture diagram is as follows: | ||
|
||
![Cluster Synchronization Architecture Diagram](/architecture-c2c.svg) | ||
|
||
When the source and destination are standalone nodes, the synchronization architecture diagram is as follows: | ||
|
||
![Standalone Node Synchronization Architecture Diagram](/architecture-s2s.svg) | ||
|
||
## Architecture Description | ||
|
||
As seen in the architecture diagram, data synchronization from the source to the destination mainly goes through three parts: Cluster Reader, Main, and Cluster Writer. | ||
|
||
### Cluster Reader | ||
|
||
The Cluster Reader is the cluster reading class. It creates an equal number of Standalone Readers based on the number of source shards. Each Standalone Reader opens a goroutine to read from each source shard in parallel and stores the data in the corresponding channel (Reader Channel) for the next stage to process. | ||
|
||
### Main | ||
|
||
Main is the main function. It opens multiple goroutines based on the number of Reader Channels, performing Parse, Filter, and Function operations on the data in the channels in parallel, and then calls the Cluster Writer's Write method to distribute the data to the write end. | ||
|
||
- Parse: Data packet parsing | ||
- Filter: Filtering operation | ||
- Function: Executes Lua functions | ||
|
||
### Cluster Writer | ||
|
||
The Cluster Writer is the cluster writing class. It creates an equal number of Standalone Writers based on the number of destination shards. The Cluster Writer's Write method can distribute data to the corresponding Standalone Writer's channel (Writer Channel) for the appropriate slot, and the Standalone Writer then writes the data to the destination. | ||
|
||
## Performance and Resource Usage | ||
|
||
### Test Environment | ||
|
||
- Server: ecs.i4g.8xlarge 32 cores, disk read speed 2.4 GB/s, write speed 1.5 GB/s | ||
- Source and destination Redis clusters: 1 GB 12 shards | ||
|
||
### Test Tool | ||
|
||
- redis-benchmark: Redis pressure testing tool, used to create continuous write traffic for the source | ||
|
||
Test cases were designed for both redisshake modes (sync and scan) and for both full synchronization and incremental synchronization phases. For the full synchronization phase, data needs to be written to the source in advance before starting redisshake synchronization. For the incremental synchronization phase, redisshake synchronization is started first, then redis-benchmark is used to continuously generate write traffic. | ||
|
||
In sync mode, the full synchronization phase synchronizes an rdb file, while the incremental synchronization phase is an aof data stream. In scan mode, full synchronization uses scan to traverse the source database, while the incremental synchronization phase enables ksn for key-value synchronization. | ||
|
||
For the incremental synchronization phase, the redis-benchmark script is set as follows, generating about 1500k/s write requests, which can fully occupy the first 16 CPU cores of the ECS server. | ||
|
||
```bash | ||
taskset -c 0-15 redis-benchmark \ | ||
--threads 16 -r 10000000 -n 1000000000 -t set \ | ||
-h host -a 'username:password' \ | ||
--cluster -c 256 -d 8 -P 2 | ||
``` | ||
|
||
Test results can be found at [RedisShake Cloud Performance Test Results](https://github.com/OxalisCu/RedisShake/tree/benchmark-backup-cloud/demo) | ||
|
||
### Performance Data | ||
|
||
The synchronization rates for both source cluster to destination cluster synchronization methods were compared. | ||
|
||
- 12c-12c: One redisshake using Cluster mode for synchronization | ||
- 12(s-s): Each shard starts one redisshake using Standalone mode for synchronization | ||
|
||
The obtained synchronization rates are as follows, where "bench" represents the write traffic rate generated by redis-benchmark. In scan mode, count is set to 10. | ||
|
||
| | bench | 12c-12c | 12(s-s) | 12c-12c/12(s-s) | | ||
| --------------- | ----- | ------- | --------------- | --------------- | | ||
| **sync + aof** | 1599k | 1520k | 12*(130k)=1560k | 0.97 | | ||
| **sync + rdb** | | 1498k | 12*(220k)=2640k | 0.57 | | ||
| **scan + ksn** | 1084k | 1081k | 12*(95k)=1140k | 0.95 | | ||
| **scan + scan** | | 665k | 12*(58k)=696k | 0.95 | | ||
|
||
### Resource Consumption | ||
|
||
CPU usage and disk read/write rates were monitored using the htop tool, while network send/receive rates were monitored using the iftop tool. The results are as follows: | ||
|
||
| | CPU | Network | Disk | | ||
| --------------- | ------------------------------------- | ----------------------------------------- | ---------- | | ||
| **sync + aof** | 16 cores at 70%-90%, total 1276.9% | Send 1340Mb/s, Receive 998Mb/s | 155.91MB/s | | ||
| **sync + rdb** | 32 cores at 50%-60%, total 1605.0% | Send 435Mb/s, Receive 82.1 Mb/s | 113.53KB/s | | ||
| **scan + ksn** | 16 cores at 90%-100%, total 1911.4% | Send 2100Mb/s, Receive 1330 Mb/s | 172.07KB/s | | ||
| **scan + scan** | 32 cores at 40%-60%, total 1297.2% | Send 1130Mb/s, Receive 533Mb/s | 155.78KB/s | |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters