Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

dev/reference/tools/dm: support new column-mapping syntax #1166

Merged
merged 5 commits into from
May 30, 2019
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
---
title: Data Migration Task Configuration File
summary: This document introduces the task configuration file of Data Migration.
summary: This document introduces the task configuration file of Data Migration.
category: reference
aliases: ['/docs/tools/dm/task-configuration-file-intro/']
---
Expand Down Expand Up @@ -99,14 +99,14 @@ column-mappings:
expression: "partition id"
source-column: "id"
target-column: "id"
arguments: ["1", "test_", "t_"]
arguments: ["1", "test", "t", "_"]
cm-rule-2:
schema-pattern: "test_*"
table-pattern: "t_*"
expression: "partition id"
source-column: "id"
target-column: "id"
arguments: ["2", "test_", "t_"]
arguments: ["2", "test", "t", "_"]

# Configuration arguments of running mydumper.
mydumpers:
Expand Down
47 changes: 30 additions & 17 deletions dev/reference/tools/data-migration/features/overview.md
Original file line number Diff line number Diff line change
Expand Up @@ -362,14 +362,14 @@ column-mappings:
​ expression: "partition id"
​ source-column: "id"
​ target-column: "id"
​ arguments: ["1", "test_", "t_"]
​ arguments: ["1", "test", "t", "_"]
rule-2:
​ schema-pattern: "test_*"
​ table-pattern: "t_*"
​ expression: "partition id"
​ source-column: "id"
​ target-column: "id"
​ arguments: ["2", "test_", "t_"]
​ arguments: ["2", "test", "t", "_"]
```

### Parameter explanation
Expand All @@ -386,35 +386,48 @@ column-mappings:

Note the following restrictions:

- The `partition id` expression only supports the bigint type of atuo-increment primary key.
- The schema name format must be `the schema prefix + number (the schema ID)`. For example, it supports `s_1`, but does not support `s_a`.
- The table name format must be `the table name + number (the table ID)`.
- The `partition id` expression only supports the bigint type of auto-increment primary key.
- If the `schema prefix` is not empty, the schema name format must be `schema prefix` or `schema prefix + separator + number (the schema ID)`. For example, it supports `s` and `s_1`, but does not support `s_a`.
- If the `table prefix` is not empty, the table name format must be `table prefix` or `table prefix + separator + number (the table ID)`.
- If the schema/table name does not contain the `… + separator + number` part, the corresponding ID is considered as 0.
kennytm marked this conversation as resolved.
Show resolved Hide resolved
- Restrictions on sharding size:
- It supports 16 MySQL or MariaDB instances at most (0 <= instance ID <= 15).
- Each instance supports 128 schemas at most (0 <= schema ID <= 127).
- Each schema of each instance supports 256 tables at most (0 <= table ID <= 255).
- The ID range of the auto-increment primary key is "0 <= ID <= 17592186044415".
- The `{instance IDschema IDtable ID}` group must be unique.
- The `{instance ID, schema ID, table ID}` group must be unique.
- Currently, the `partition id` expression is a customized feature. If you want to modify this feature, contact the corresponding developers.

**`partition id` arguments configuration**

Configure the following three arguments in order:
Configure the following 3–4 arguments in order:
kennytm marked this conversation as resolved.
Show resolved Hide resolved

- `instance_id`: the ID of the upstream sharded MySQL or MariaDB instance (0 <= instance ID <= 15)
- The schema prefix: used to parse the schema name and get the `schema ID`
- The table prefix: used to parse the table name and get the `table ID`
- `schema prefix`: used to parse the schema name and get the `schema ID`
- `table prefix`: used to parse the table name and get the `table ID`
- The separator: used to separate between the prefix and the IDs, and can be omitted to use an empty string as separator

Any of `instance_id`, `schema prefix` and `table prefix` can be set to an empty string (`""`) to indicate the corresponding parts will not be encoded into the partition ID.
kennytm marked this conversation as resolved.
Show resolved Hide resolved

**`partition id` expression rules**

`partition id` fills the beginning bit of the auto-increment primary key ID with the argument number, and computes an int64 (MySQL bigint) type of value. The specific rules are as follows:

- int64 bit indicates `[1:1 bit] [2:4 bits] [3:7 bits] [4:8 bits] [5: 44 bits]`.
- `1`: the sign bit, reserved
- `2`: the instance ID, 4 bits by default
- `3`: the schema ID, 7 bits by default
- `4`: the table ID, 8 bits by default
- `5`: the auto-increment primary key ID, 44 bits by default
| instance_id | schema prefix | table prefix | Encoding |
|:------------|:--------------|:-------------|---------:|
| ☑ defined | ☑ defined | ☑ defined | [`S`: 1 bit] [`I`: 4 bits] [`D`: 7 bits] [`T`: 8 bits] [`P`: 44 bits] |
| ☐ empty | ☑ defined | ☑ defined | [`S`: 1 bit] [`D`: 7 bits] [`T`: 8 bits] [`P`: 48 bits] |
| ☑ defined | ☐ empty | ☑ defined | [`S`: 1 bit] [`I`: 4 bits] [`T`: 8 bits] [`P`: 51 bits] |
| ☑ defined | ☑ defined | ☐ empty | [`S`: 1 bit] [`I`: 4 bits] [`D`: 7 bits] [`P`: 52 bits] |
| ☐ empty | ☐ empty | ☑ defined | [`S`: 1 bit] [`T`: 8 bits] [`P`: 55 bits] |
| ☐ empty | ☑ defined | ☐ empty | [`S`: 1 bit] [`D`: 7 bits] [`P`: 56 bits] |
| ☑ defined | ☐ empty | ☐ empty | [`S`: 1 bit] [`I`: 4 bits] [`P`: 59 bits] |

- `S`: the sign bit, reserved
- `I`: the instance ID, 4 bits by default if set
- `D`: the schema ID, 7 bits by default if set
- `T`: the table ID, 8 bits by default if set
- `P`: the auto-increment primary key ID, occupying the rest of bits (≥44 bits)

### Usage example

Expand All @@ -430,14 +443,14 @@ column-mappings:
​ expression: "partition id"
​ source-column: "id"
​ target-column: "id"
​ arguments: ["1", "test_", "t_"]
​ arguments: ["1", "test", "t", "_"]
rule-2:
​ schema-pattern: "test_*"
​ table-pattern: "t_*"
​ expression: "partition id"
​ source-column: "id"
​ target-column: "id"
​ arguments: ["2", "test_", "t_"]
​ arguments: ["2", "test", "t", "_"]
```

- The column ID of the MySQL instance 1 table `test_1`.`t_1` is converted from `1` to `1 << (64-1-4) | 1 << (64-1-4 -7) | 1 << 44 | 1 = 580981944116838401`.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -135,21 +135,21 @@ Assume that the downstream schema after synchronization is as follows:
expression: "partition id"
source-column: "id"
target-column: "id"
arguments: ["1", "store_", "sale_"]
arguments: ["1", "store", "sale", "_"]
instance-2-sale:
schema-pattern: "store_*"
table-pattern: "sale_*"
expression: "partition id"
source-column: "id"
target-column: "id"
arguments: ["2", "store_", "sale_"]
arguments: ["2", "store", "sale", "_"]
instance-3-sale:
schema-pattern: "store_*"
table-pattern: "sale_*"
expression: "partition id"
source-column: "id"
target-column: "id"
arguments: ["3", "store_", "sale_"]
arguments: ["3", "store", "sale", "_"]
```

## Synchronization task configuration
Expand Down Expand Up @@ -241,21 +241,21 @@ column-mappings:
expression: "partition id"
source-column: "id"
target-column: "id"
arguments: ["1", "store_", "sale_"]
arguments: ["1", "store", "sale", "_"]
instance-2-sale:
schema-pattern: "store_*"
table-pattern: "sale_*"
expression: "partition id"
source-column: "id"
target-column: "id"
arguments: ["2", "store_", "sale_"]
arguments: ["2", "store", "sale", "_"]
instance-3-sale:
schema-pattern: "store_*"
table-pattern: "sale_*"
expression: "partition id"
source-column: "id"
target-column: "id"
arguments: ["3", "store_", "sale_"]
arguments: ["3", "store", "sale", "_"]

mydumpers:
global:
Expand Down