title | summary |
---|---|
DM Cluster Performance Test |
Learn how to test the performance of DM clusters. |
This document describes how to build a test scenario to do a performance test on the DM cluster, including the speed test and latency test regarding data migration.
You can use a simple migration data flow, that is, MySQL -> DM -> TiDB, to test the data migration performance of the DM cluster.
- Deploy the TiDB test cluster using TiUP, with all default configurations.
- Deploy the MySQL service. Enable the
ROW
mode for binlog, and use default configurations for other configuration items. - Deploy a DM cluster, with a DM-worker and a DM-master.
Use tables with the following schema for the performance test:
{{< copyable "sql" >}}
CREATE TABLE `sbtest` (
`id` int NOT NULL AUTO_INCREMENT,
`k` int NOT NULL DEFAULT '0',
`c` char(120) CHARSET utf8mb4 COLLATE utf8mb4_bin NOT NULL DEFAULT '',
`pad` char(60) CHARSET utf8mb4 COLLATE utf8mb4_bin NOT NULL DEFAULT '',
PRIMARY KEY (`id`),
KEY `k_1` (`k`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin
Use sysbench
to create test tables upstream and generate test data for full import. Execute the following sysbench
command to generate test data:
{{< copyable "shell-regular" >}}
sysbench --test=oltp_insert --tables=4 --mysql-host=172.16.4.40 --mysql-port=3306 --mysql-user=root --mysql-db=dm_benchmark --db-driver=mysql --table-size=50000000 prepare
-
Create an upstream MySQL source and set
source-id
tosource-1
. For details, see Load the Data Source Configurations. -
Create a migration task (in
full
mode). The following is a task configuration template:
---
name: test-full
task-mode: full
# Configure the migration task using the TiDB information of your actual test environment.
target-database:
host: "192.168.0.1"
port: 4000
user: "root"
password: ""
mysql-instances:
-
source-id: "source-1"
block-allow-list: "instance"
mydumper-config-name: "global"
loader-thread: 16
# Configure the name of the database where sysbench generates data.
block-allow-list:
instance:
do-dbs: ["dm_benchmark"]
mydumpers:
global:
rows: 32000
threads: 32
For details about how to create a migration task, see Create a Data Migration Task.
Note:
- To enable concurrently exporting data from a single table using multi-thread, you can use the
rows
option in themydumpers
configuration item. This speeds up data export.- To test the performance under different configurations, you can tune
loader-thread
in themysql-instances
configuration, as well asrows
andthreads
in themydumpers
configuration item.
Observe the DM-worker log. When you see all data files have been finished
, it means that full data has been imported. In this case, you can see the time consumed to import data. The sample log is as follows:
[INFO] [loader.go:604] ["all data files have been finished"] [task=test] [unit=load] ["cost time"=52.439796ms]
According to the size of the test data and the time consumed to import data, you can calculate the migration speed of the full data.
Use sysbench
to create test tables in the upstream.
-
Create the source of the upstream MySQL. Set
source-id
tosource-1
(if the source has been created in the full import benchmark case, you do not need to create it again). For details, see Load the Data Source Configurations. -
Create a DM migration task (in
all
mode). The following is an example of the task configuration file:
---
name: test-all
task-mode: all
# Configure the migration task using the TiDB information of your actual test environment.
target-database:
host: "192.168.0.1"
port: 4000
user: "root"
password: ""
mysql-instances:
-
source-id: "source-1"
block-allow-list: "instance"
syncer-config-name: "global"
# Configure the name of the database where sysbench generates data.
block-allow-list:
instance:
do-dbs: ["dm_benchmark"]
syncers:
global:
worker-count: 16
batch: 100
For details about how to create a data migration task, see Create a Data Migration Task.
Note:
To test the performance under different configurations, you can tune
worker-count
andbatch
in thesyncers
configuration item.
To continuously generate incremental data in the upstream, run the sysbench
command:
{{< copyable "shell-regular" >}}
sysbench --test=oltp_insert --tables=4 --num-threads=32 --mysql-host=172.17.4.40 --mysql-port=3306 --mysql-user=root --mysql-db=dm_benchmark --db-driver=mysql --report-interval=10 --time=1800 run
Note:
You can test the data migration performance under different scenarios by using different
sysbench
statements.
To observe the migration status of DM, you can run the query-status
command. To observe the monitoring metrics of DM, you can use Grafana. Here the monitoring metrics refer to finished sqls jobs
(the number of jobs finished per unit time), and other related metrics. For more information, see Binlog Migration Monitoring Metrics.