title | summary | category |
---|---|---|
Manage the Data Synchronization Task |
Use dmctl to manage the data synchronization task. |
tools |
This document describes how to manage and maintain the data synchronization task using the dmctl component. For the Data Migration cluster deployed using DM-Ansible, the dmctl binary file is in dm-ansible/dmctl
.
This section shows the basic usage of dmctl commands.
$ ./dmctl --help
Usage of dmctl:
# Prints the version information.
-V prints version and exit
# Encrypts the database password according to the encryption method provided by DM; used in DM configuration files.
-encrypt string
encrypt plaintext to ciphertext
# The dm-master access address. dmctl interacts with dm-master to complete task management operations.
-master-addr string
master API server addr
In DM configuration files, you need to use the password encrypted using dmctl, otherwise an error occurs. For a same original password, the password is different after each encryption.
$ ./dmctl -encrypt 123456
VjX8cEeTX+qcvZ3bPaO4h0C80pe/1aU=
# Enters the command line mode to interact with DM-master.
$ ./dmctl -master-addr 172.16.30.14
Welcome to dmctl
Release Version: v1.0.0-100-g2bef6f8b
Git Commit Hash: 2bef6f8beda34c0dff57377005c71589b48aa3c5
Git Branch: dm-master
UTC Build Time: 2018-11-02 10:03:18
Go Version: go version go1.11 linux/amd64
» help
DM control
Usage:
dmctl [command]
Available Commands:
break-ddl-lock force to break DM-worker's DDL lock
generate-task-config generate a task config with config file
help Help about any command
pause-relay pause DM-worker's relay unit
pause-task pause a running task with name
query-status query task's status
refresh-worker-tasks refresh worker -> tasks mapper
resume-relay resume DM-worker's relay unit
resume-task resume a paused task with name
show-ddl-locks show un-resolved DDL locks
sql-inject sql-inject injects (limited) sqls into syncer as binlog event
sql-replace sql-replace replaces sql in specific binlog_pos with other sqls, each sql must ends with semicolon;
sql-skip sql-skip skips specified binlog position
start-task start a task with config file
stop-task stop a task with name
switch-relay-master switch master server of DM-worker's relay unit
unlock-ddl-lock force to unlock DDL lock
update-master-config update configure of DM-master
update-task update a task's config for routes, filters, column-mappings, black-white-list
Flags:
-h, --help help for dmctl
-w, --worker strings DM-worker ID
# Use "dmctl [command] --help" for more information about a command.
To detect possible errors of data synchronization configuration in advance, DM provides the precheck feature. You can use the check-task
command to precheck whether the upstream MySQL instance configuration satisfies the DM requirements.
The user of the upstream and downstream databases must have the corresponding read and write privileges. DM checks the following privileges and configuration automatically while starting the data synchronization task:
-
MySQL binlog configuration
- Whether the binlog is enabled (DM requires that the binlog must be enabled)
- Whether
binlog_format=ROW
(DM only supports the binlog synchronization in the ROW format) - Whether
binlog_row_image=FULL
(DM only supportsbinlog_row_image=FULL
)
-
The privileges of the upstream MySQL instance user
The MySQL user in DM configuration needs to have the following privileges at least:
- REPLICATION SLAVE
- REPLICATION CLIENT
- RELOAD
- SELECT
-
The compatibility of the upstream MySQL table schema
TiDB differs from MySQL in compatibility in the following aspects:
- Does not support the foreign key
- Character set compatibility differs
-
The consistency check on the upstream MySQL multiple-instance shards
-
The schema consistency of all sharded tables
- Column size
- Column name
- Column position
- Column type
- Primary key
- Unique index
-
The conflict of the auto increment primary keys in the sharded tables
-
The check fails in the following two conditions:
- The auto increment primary key exists in the sharded tables and its column type is not bigint.
- The auto increment primary key exists in the sharded tables and its column type is bigint, but column mapping is not configured.
-
The check succeeds in other conditions except the two above.
-
-
This section describes how to use the task management commands to execute the following operations:
- Create the data synchronization task
- Check the data synchronization task status
- Pause the data synchronization task
- Restart the data synchronization task
- Stop the data synchronization task
- Update the data synchronization task
You can use the task management command to create the data synchronization task. Data Migration prechecks the corresponding privileges and configuration automatically while starting the data synchronization.
» help start-task
start a task with config file
Usage:
dmctl start-task [-w worker ...] <config_file> [flags]
Flags:
-h, --help help for start-task
Global Flags:
-w, --worker strings dm-worker ID
start-task [ -w "172.16.30.15:10081"] ./task.yaml
-w
: (Optional) This flag specifies the group of DM-workers to executetask.yaml
. If it is set, only subtasks of the specified task on these DM-workers are started.config_file
: (Required) This flag specifies the file path oftask.yaml
.
{
"result": true,
"msg": "",
"workers": [
{
"result": true,
"worker": "172.16.30.15:10081",
"msg": ""
},
{
"result": true,
"worker": "172.16.30.16:10081",
"msg": ""
}
]
}
You can use the task management command to check the status of the data synchronization task.
» help query-status
query task's status
Usage:
dmctl query-status [-w worker ...] [task_name] [flags]
Flags:
-h, --help help for query-status
Global Flags:
-w, --worker strings dm-worker ID
query-status
-w
: (Optional) This flag specifies the group of DM-workers where the subtasks of the synchronization task (that you want to query) run.task_name
: (Optional) This flag specifies the task name. If it is not set, the results of all data synchronization tasks are returned.
» query-status
{
"result": true,
"msg": "",
"workers": [
{
"result": true,
"worker": "172.16.30.15:10081",
"msg": "",
"subTaskStatus": [
{
"name": "test",
"stage": "Running",
"unit": "Sync",
"result": null,
"unresolvedDDLLockID": "",
"sync": {
"TotalEvents": "0",
"TotalTps": "0",
"RecentTps": "0",
"MasterBinlog": "(mysql-bin.000004, 484)",
"MasterBinlogGtid": "",
"SyncerBinlog": "(mysql-bin.000004, 484)",
"SyncerBinlogGtid": "",
"blockingDDLs": [
],
"unresolvedGroups": [
]
}
}
],
"relayStatus": {
"MasterBinlog": "(mysql-bin.000004, 484)",
"MasterBinlogGtid": "",
"relaySubDir": "0-1.000001",
"RelayBinlog": "(mysql-bin.000004, 484)",
"RelayBinlogGtid": "",
"relayCatchUpMaster": true,
"stage": "Running",
"result": null
}
},
{
"result": true,
"worker": "172.16.30.16:10081",
"msg": "",
"subTaskStatus": [
{
"name": "test",
"stage": "Running",
"unit": "Sync",
"result": null,
"unresolvedDDLLockID": "",
"sync": {
"TotalEvents": "0",
"TotalTps": "0",
"RecentTps": "0",
"MasterBinlog": "(mysql-bin.000004, 4809)",
"MasterBinlogGtid": "",
"SyncerBinlog": "(mysql-bin.000004, 4809)",
"SyncerBinlogGtid": "",
"blockingDDLs": [
],
"unresolvedGroups": [
]
}
}
],
"relayStatus": {
"MasterBinlog": "(mysql-bin.000004, 4809)",
"MasterBinlogGtid": "",
"relaySubDir": "0-1.000001",
"RelayBinlog": "(mysql-bin.000004, 4809)",
"RelayBinlogGtid": "",
"relayCatchUpMaster": true,
"stage": "Running",
"result": null
}
}
]
}
You can use the task management command to pause the data synchronization task.
» help pause-task
pause a running task with name
Usage:
dmctl pause-task [-w worker ...] <task_name> [flags]
Flags:
-h, --help help for pause-task
Global Flags:
-w, --worker strings DM-worker ID
pause-task [-w "127.0.0.1:10181"] task-name
-w
: (Optional) This flag specifies the group of DM-workers where the subtasks of the synchronization task (that you want to pause) run. If it is set, only subtasks on the specified DM-workers are paused.task_name
: (Required) This flag specifies the task name.
» pause-task test
{
"op": "Pause",
"result": true,
"msg": "",
"workers": [
{
"op": "Pause",
"result": true,
"worker": "172.16.30.15:10081",
"msg": ""
},
{
"op": "Pause",
"result": true,
"worker": "172.16.30.16:10081",
"msg": ""
}
]
}
You can use the task management command to restart the data synchronization task.
» help resume-task
resume a paused task with name
Usage:
dmctl resume-task [-w worker ...] <task_name> [flags]
Flags:
-h, --help help for resume-task
Global Flags:
-w, --worker strings dm-worker ID
resume-task [-w "127.0.0.1:10181"] task-name
-w
: (Optional) This flag specifies the group of DM-workers where the subtasks of the synchronization task (that you want to restart) run. If it is set, only subtasks on the specified DM-workers are restarted.task_name
: (Required) This flag specifies the task name.
» resume-task test
{
"op": "Resume",
"result": true,
"msg": "",
"workers": [
{
"op": "Resume",
"result": true,
"worker": "172.16.30.15:10081",
"msg": ""
},
{
"op": "Resume",
"result": true,
"worker": "172.16.30.16:10081",
"msg": ""
}
]
}
You can use the task management command to stop the data synchronization task.
» help stop-task
stop a task with name
Usage:
dmctl stop-task [-w worker ...] <task_name> [flags]
Flags:
-h, --help help for stop-task
Global Flags:
-w, --worker strings dm-worker ID
stop-task [-w "127.0.0.1:10181"] task-name
-w
: (Optional) This flag specifies the group of DM-workers where the subtasks of the synchronization task (that you want to stop) run. If it is set, only subtasks on the specified DM-workers are stopped.task_name
: (Required) This flag specifies the task name.
» stop-task test
{
"op": "Stop",
"result": true,
"msg": "",
"workers": [
{
"op": "Stop",
"result": true,
"worker": "172.16.30.15:10081",
"msg": ""
},
{
"op": "Stop",
"result": true,
"worker": "172.16.30.16:10081",
"msg": ""
}
]
}
You can use the task management command to update the data synchronization task. The following items support online update, while all other items do not support online update.
- table route rules
- black white list
- binlog filter rules
- column mapping rules
-
Check the status of the corresponding data synchronization task using
query-status <task-name>
.If
stage
is notPaused
, usepause-task <task-name>
to pause the task. -
Edit the
task.yaml
file to update the custom configuration that you need to modify and the incorrect configuration. -
Update the task configuration using
update-task task.yaml
. -
Restart the task using
resume-task <task-name>
.
-
Check the status of the corresponding data synchronization task using
query-status <task-name>
.If the task exists, use
stop-task <task-name>
to stop the task. -
Edit the
task.yaml
file to update the custom configuration that you need to modify and the incorrect configuration. -
Restart the task using
start-task <task-name>
.
» help update-task
update a task's config for routes, filters, column-mappings, black-white-list
Usage:
dmctl update-task [-w worker ...] <config_file> [flags]
Flags:
-h, --help help for update-task
Global Flags:
-w, --worker strings dm-worker ID
update-task [-w "127.0.0.1:10181"] ./task.yaml
-w
: (Optional) This flag specifies the group of DM-workers where the subtasks of the synchronization task (that you want to update) run. If it is set, only subtasks on the specified DM-workers are updated.config_file
: (Required) This flag specifies the file path oftask.yaml
.
» update-task task_all_black.yaml
{
"result": true,
"msg": "",
"workers": [
{
"result": true,
"worker": "172.16.30.15:10081",
"msg": ""
},
{
"result": true,
"worker": "172.16.30.16:10081",
"msg": ""
}
]
}
See Troubleshooting Sharding DDL Locks.
You can use the refresh-worker-tasks
command to forcefully refresh the task => DM-workers
mapping maintained in the DM-master memory.
Note: Generally, you do not need to use it. You can use it only when you are ensured that the
task => DM-workers
mapping exists, but you are still prompted to refresh while you are executing other commands.