title | summary | aliases | |
---|---|---|---|
TiDB Data Migration Quick Start |
Learn how to quickly deploy a DM cluster using binary packages. |
|
This document describes how to migrate data from MySQL to TiDB using TiDB Data Migration (DM). This guide is a quick demo of DM features and is not recommended for any production environment.
Note:
If your target machine's operating system supports SELinux, ensure that SELinux is disabled.
-
Install TiUP, and install
dmctl
using TiUP:{{< copyable "shell-regular" >}}
curl --proto '=https' --tlsv1.2 -sSf https://tiup-mirrors.pingcap.com/install.sh | sh tiup install dm dmctl
-
Generate the minimal deployment topology file of a DM cluster:
{{< copyable "shell-regular" >}}
tiup dm template
-
Copy the configuration information in the output, and save it as the
topology.yaml
file with the modified IP address. Deploy the DM cluster with thetopology.yaml
file using TiUP:{{< copyable "shell-regular" >}}
tiup dm deploy dm-test 8.5.0 topology.yaml -p
You can use one or multiple MySQL instances as an upstream data source.
-
Create a configuration file for each data source as follows:
{{< copyable "shell-regular" >}}
source-id: "mysql-01" from: host: "127.0.0.1" user: "root" password: "fCxfQ9XKCezSzuCD0Wf5dUD+LsKegSg=" port: 3306
-
Add the source to the DM cluster by running the following command.
mysql-01.yaml
is the configuration file created in the previous step.{{< copyable "shell-regular" >}}
tiup dmctl --master-addr=127.0.0.1:8261 operate-source create mysql-01.yaml # use one of master_servers as the argument of --master-addr
If you do not have a MySQL instance for testing, you can create a MySQL instance in Docker by taking the following steps:
-
Create a MySQL configuration file:
{{< copyable "shell-regular" >}}
mkdir -p /tmp/mysqltest && cd /tmp/mysqltest cat > my.cnf <<EOF [mysqld] bind-address = 0.0.0.0 character-set-server=utf8 collation-server=utf8_bin default-storage-engine=INNODB transaction-isolation=READ-COMMITTED server-id = 100 binlog_format = row log_bin = /var/lib/mysql/mysql-bin.log show_compatibility_56 = ON EOF
-
Start the MySQL instance using Docker:
{{< copyable "shell-regular" >}}
docker run --name mysql-01 -v /tmp/mysqltest:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=my-secret-pw -d -p 3306:3306 mysql:5.7
-
After the MySQL instance is started, access the instance:
Note:
This command is only suitable for trying out data migration, and cannot be used in production environments or stress tests.
{{< copyable "shell-regular" >}}
mysql -uroot -p -h 127.0.0.1 -P 3306
You can choose an existing TiDB cluster as a target for data migration.
If you do not have a TiDB cluster for testing, you can quickly build a demonstration environment by running the following command:
{{< copyable "shell-regular" >}}
tiup playground
Create a test table and data in one or multiple data sources. If you use an existing MySQL database, and the database contains available data, you can skip this step.
{{< copyable "sql" >}}
drop database if exists `testdm`;
create database `testdm`;
use `testdm`;
create table t1 (id bigint, uid int, name varchar(80), info varchar(100), primary key (`id`), unique key(`uid`)) DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin;
create table t2 (id bigint, uid int, name varchar(80), info varchar(100), primary key (`id`), unique key(`uid`)) DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin;
insert into t1 (id, uid, name) values (1, 10001, 'Gabriel García Márquez'), (2, 10002, 'Cien años de soledad');
insert into t2 (id, uid, name) values (3, 20001, 'José Arcadio Buendía'), (4, 20002, 'Úrsula Iguarán'), (5, 20003, 'José Arcadio');
-
Create a task configuration file
testdm-task.yaml
:{{< copyable "" >}}
name: testdm task-mode: all target-database: host: "127.0.0.1" port: 4000 user: "root" password: "" # If the password is not empty, it is recommended to use a password encrypted with dmctl. # Configure the information of one or multiple data sources mysql-instances: - source-id: "mysql-01" block-allow-list: "ba-rule1" block-allow-list: ba-rule1: do-dbs: ["testdm"]
-
Create the task using dmctl:
{{< copyable "shell-regular" >}}
tiup dmctl --master-addr 127.0.0.1:8261 start-task testdm-task.yaml
You have successfully created a task that migrates data from a mysql-01
database to TiDB.
After the task is created, you can use the dmctl query-status
command to check the status of the task:
{{< copyable "shell-regular" >}}
tiup dmctl --master-addr 127.0.0.1:8261 query-status testdm