Transfer Partition
当自动的负载均衡无法满足用户对于特定分区的聚合和打散需求时,可以手动发起 Transfer Partition 操作。
使用限制及注意事项
- 执行 Transfer Partition 操作的用户需要拥有
ALTER SYSTEM权限。有关权限的详细介绍,请参见 用户和权限概述。 - 仅支持在主租户上执行 Transfer Partition 操作,并且只能 Transfer 用户租户下的分区。
- 关闭租户的 Transfer 功能(即租户下配置项
enable_transfer的值为false)后,对该租户执行TRANSFER PARTITION语句会报错,已经执行成功了的TRANSFER PARTITION语句,其对应的 Transfer Partition 任务可能会被取消。 - 不支持对系统表执行 Transfer Partition 操作。
- 不支持对系统租户下的用户表执行 Transfer Partition 操作。
- 不支持将普通表 Transfer 到广播日志流上,同时也不支持将复制表 Transfer 到普通日志流上。
- 不支持 Transfer 非独立的分区,例如,局部索引表的分区和 LOB 表的分区不支持 Transfer。
- 对于同一个分区,在 Transfer Partition 操作未完成之前,不允许再次发起 Transfer Partition 操作。
- 如果当前集群中已经有一个均衡任务(BALANCE_JOB)正在处理,手动触发的 Transfer Partition 任务不会立刻开始调度。
前提条件
-
Transfer Partition 前,需要开启 Transfer 功能。Transfer 功能由租户级配置项
enable_transfer控制,默认值为true,表示开启 Transfer 功能。有关配置项enable_transfer的详细说明及设置,请参见 enable_transfer。 -
由于 Transfer Partition 策略与自动均衡策略可能会有冲突,为了保证分区位置固定,建议您在执行 Transfer Partition 操作前关闭自动均衡策略,即,将对应租户下配置项
enable_rebalance的值设置为false。有关配置项enable_rebalance的详细说明及设置,请参见 enable_rebalance。Transfer Partition 操作本身不受配置项
enable_rebalance的控制,但当enable_rebalance与enable_transfer的值均为true时,可能会出现用户将某个分区迁移到对应的日志流上后,系统的自动均衡策略又将该分区迁移到其他日志流上的情况。
系统租户 Transfer Partition
-
使用
root用户登录到集群的sys租户。连接示例如下,连接数据库时请以实际环境为准。
obclient -h10.xx.xx.xx -P2883 -uroot@sys#obdemo -p***** -A -
查询视图
DBA_OB_TENANTS,获取目标租户的TENANT_ID。obclient [oceanbase]> SELECT TENANT_ID FROM oceanbase.DBA_OB_TENANTS WHERE TENANT_NAME = 'oracle_tenant';查询结果如下:
+-----------+ | TENANT_ID | +-----------+ | 1006 | +-----------+ 1 row in set -
确认分区信息。
可以通过查询视图
CDB_OB_TABLE_LOCATIONS,获取指定分区的TABLET_ID、OBJECT_ID以及LS_ID。-
获取非分区表的
TABLET_ID、OBJECT_ID以及LS_ID假设
oracle_tenant租户下存在非分区表T1,查询示例如下:obclient [oceanbase]> SELECT TABLE_ID AS TABLE_ID, OBJECT_ID, TABLET_ID, LS_ID FROM oceanbase.CDB_OB_TABLE_LOCATIONS WHERE TENANT_ID = 1006 AND DATABASE_NAME = 'SYS' AND TABLE_NAME= 'T1' LIMIT 1;查询结果如下:
+----------+-----------+-----------+-------+ | TABLE_ID | OBJECT_ID | TABLET_ID | LS_ID | +----------+-----------+-----------+-------+ | 500002 | 500002 | 200001 | 1001 | +----------+-----------+-----------+-------+ 1 row in set -
获取一级分区表的
TABLET_ID、OBJECT_ID以及LS_ID对于一级分区表,查询时只需要指定具体的一级分区名即可。
假设
oracle_tenant租户下存在一级分区表TBL1_LOG_R。obclient [SYS]> CREATE TABLE tbl1_log_r(log_id INT,log_date DATE NOT NULL DEFAULT SYSDATE) PARTITION BY RANGE(log_date) (PARTITION M202001 VALUES LESS THAN(TO_DATE('2020/02/01','YYYY/MM/DD')) , PARTITION M202002 VALUES LESS THAN(TO_DATE('2020/03/01','YYYY/MM/DD')) , PARTITION M202003 VALUES LESS THAN(TO_DATE('2020/04/01','YYYY/MM/DD')) , PARTITION M202004 VALUES LESS THAN(TO_DATE('2020/05/01','YYYY/MM/DD')) , PARTITION M202005 VALUES LESS THAN(TO_DATE('2020/06/01','YYYY/MM/DD')) , PARTITION M202006 VALUES LESS THAN(TO_DATE('2020/07/01','YYYY/MM/DD')) , PARTITION M202007 VALUES LESS THAN(TO_DATE('2020/08/01','YYYY/MM/DD')) , PARTITION M202008 VALUES LESS THAN(TO_DATE('2020/09/01','YYYY/MM/DD')) , PARTITION M202009 VALUES LESS THAN(TO_DATE('2020/10/01','YYYY/MM/DD')) , PARTITION M202010 VALUES LESS THAN(TO_DATE('2020/11/01','YYYY/MM/DD')) , PARTITION M202011 VALUES LESS THAN(TO_DATE('2020/12/01','YYYY/MM/DD')) , PARTITION M202012 VALUES LESS THAN(TO_DATE('2021/01/01','YYYY/MM/DD')) , PARTITION MMAX VALUES LESS THAN (MAXVALUE) );查询该一级分区表中分区
M202005相关信息的示例如下:obclient [oceanbase]> SELECT TABLE_ID AS TABLE_ID, OBJECT_ID, TABLET_ID, LS_ID FROM oceanbase.CDB_OB_TABLE_LOCATIONS WHERE TENANT_ID = 1006 AND DATABASE_NAME = 'SYS' AND TABLE_NAME= 'TBL1_LOG_R' AND PARTITION_NAME = 'M202005' LIMIT 1;查询结果如下:
+----------+-----------+-----------+-------+ | TABLE_ID | OBJECT_ID | TABLET_ID | LS_ID | +----------+-----------+-----------+-------+ | 500003 | 500009 | 200006 | 1002 | +----------+-----------+-----------+-------+ 1 row in set -
获取二级分区表的
TABLET_ID、OBJECT_ID以及LS_ID对于二级分区表,查询时需要同时指定一级分区名和二级分区名。
假设
oracle_tenant租户下存在二级分区表T2_F_RL。obclient [SYS]> CREATE TABLE t2_f_rl(col1 INT,col2 VARCHAR2(50)) PARTITION BY RANGE(col1) SUBPARTITION BY LIST(col2) (PARTITION p0 VALUES LESS THAN(100) (SUBPARTITION sp0 VALUES('01'), SUBPARTITION sp1 VALUES('02') ), PARTITION p1 VALUES LESS THAN(200) (SUBPARTITION sp2 VALUES('01'), SUBPARTITION sp3 VALUES('02'), SUBPARTITION sp4 VALUES('03') ) );查询该二级分区表中二级分区
SP2相关信息的示例如下:obclient [oceanbase]> SELECT TABLE_ID AS TABLE_ID, OBJECT_ID, TABLET_ID, LS_ID FROM oceanbase.CDB_OB_TABLE_LOCATIONS WHERE TENANT_ID = 1006 AND DATABASE_NAME = 'SYS' AND TABLE_NAME= 'T2_F_RL' AND PARTITION_NAME = 'P1' AND SUBPARTITION_NAME = 'SP2' LIMIT 1;查询结果如下:
+----------+-----------+-----------+-------+ | TABLE_ID | OBJECT_ID | TABLET_ID | LS_ID | +----------+-----------+-----------+-------+ | 500018 | 500023 | 200017 | 1003 | +----------+-----------+-----------+-------+ 1 row in set
-
-
选择 Transfer 目的端。
-
查询视图
CDB_OB_LS,获取租户的日志流状态和信息。obclient [oceanbase]> SELECT * FROM oceanbase.CDB_OB_LS WHERE TENANT_ID = 1006;查询结果如下:
+-----------+-------+--------+--------------+---------------+-------------+---------------------+----------+---------------------+---------------------+------+ | TENANT_ID | LS_ID | STATUS | PRIMARY_ZONE | UNIT_GROUP_ID | LS_GROUP_ID | CREATE_SCN | DROP_SCN | SYNC_SCN | READABLE_SCN | FLAG | +-----------+-------+--------+--------------+---------------+-------------+---------------------+----------+---------------------+---------------------+------+ | 1006 | 1 | NORMAL | zone1 | 0 | 0 | NULL | NULL | 1701244663685197789 | 1701244663685197789 | | | 1006 | 1001 | NORMAL | zone1 | 1006 | 1001 | 1701239786827662637 | NULL | 1701244663685197789 | 1701244663685197789 | | | 1006 | 1002 | NORMAL | zone1 | 1007 | 1002 | 1701239786831568305 | NULL | 1701244664066906860 | 1701244664066906859 | | | 1006 | 1003 | NORMAL | zone1 | 1008 | 1003 | 1701239786834300282 | NULL | 1701244664175263949 | 1701244664175263948 | | +-----------+-------+--------+--------------+---------------+-------------+---------------------+----------+---------------------+---------------------+------+ 4 rows in set -
查询视图
CDB_OB_TABLET_TO_LS,获取日志流上 Tablet 的分布信息。obclient [oceanbase]> SELECT LS_ID, COUNT(*) AS C FROM oceanbase.CDB_OB_TABLET_TO_LS WHERE TENANT_ID = 1006 GROUP BY LS_ID;查询结果如下:
+-------+------+ | LS_ID | C | +-------+------+ | 1 | 578 | | 1001 | 7 | | 1002 | 5 | | 1003 | 7 | +-------+------+ 4 rows in set根据上述展示的信息,选择合适的日志流作为 Transfer 目的端。
-
-
执行以下命令,进行 Transfer Partition 操作。
ALTER SYSTEM TRANSFER PARTITION TABLE_ID [=] table_id, OBJECT_ID [=] object_id TO LS ls_id TENANT = 'tenant_name';其中:
table_id:表 ID。object_id:分区的唯一标识。ls_id:Transfer 目的端的日志流 ID。tenant_name:待 Transfer 的分区所属的租户。
以租户
oracle_tenant为例,将其SYS库下的表TBL1_LOG_R的M202005分区,从当前1002号日志流迁移到1003号日志流上,示例如下。obclient [oceanbase]> ALTER SYSTEM TRANSFER PARTITION TABLE_ID = 500003, OBJECT_ID = 500009 TO LS 1003 TENANT = 'oracle_tenant'; -
Transfer Partition 命令执行成功后,可以通过以下视图查看任务状态。
-
查询视图
CDB_OB_TRANSFER_PARTITION_TASKS,获取任务的TASK_ID、TRANSFER_TASK_ID和BALANCE_JOB_ID。视图
CDB_OB_TRANSFER_PARTITION_TASKS展示了所有租户当前正在处理的分区 Transfer 任务。查询示例如下:obclient [oceanbase]> SELECT TASK_ID, BALANCE_JOB_ID, TRANSFER_TASK_ID, STATUS FROM oceanbase.CDB_OB_TRANSFER_PARTITION_TASKS WHERE TENANT_ID = 1006 AND TABLE_ID = 500003 AND OBJECT_ID = 500009;查询结果的示例如下:
+---------+----------------+------------------+--------+ | TASK_ID | BALANCE_JOB_ID | TRANSFER_TASK_ID | STATUS | +---------+----------------+------------------+--------+ | 1 | 17304 | 1 | DOING | +---------+----------------+------------------+--------+ 1 row in set可以根据查询结果中
STATUS的值确认任务状态,进一步查看任务执行进度:WAITING: 表示任务在等待中,还没有开始调度。INIT:表示任务已经构建BALANCE_JOB了,您可以根据BALANCE_JOB_ID查看关联的BALANCE_JOB执行进度。DOING: 表示任务已经开始执行 Transfer 了,您可以根据TRANSFER_TASK_ID查看关联的 Transfer Partition 任务,TRANSFER_TASK_ID会变化很多次,一个 Transfer Partition 任务会涉及多次 Transfer。
如果视图
CDB_OB_TRANSFER_PARTITION_TASKS的查询结果为空,可以通过视图CDB_OB_TRANSFER_PARTITION_TASK_HISTORY来查看任务结果。 -
根据获取的
BALANCE_JOB_ID查询视图CDB_OB_BALANCE_JOBS或CDB_OB_BALANCE_JOB_HISTORY,确认关联的 BALANCE_JOB 的执行状态。视图
CDB_OB_BALANCE_JOBS展示了所有租户当前正在执行的负载均衡工作。每个租户同一时间只有一个负载均衡工作(BALANCE_JOB),每个工作会生成多个负载均衡任务(TRANSFER_TASK)。视图CDB_OB_BALANCE_JOB_HISTORY展示了所有租户已执行的负载均衡工作历史。查询示例如下:obclient [oceanbase]> SELECT * FROM oceanbase.CDB_OB_BALANCE_JOBS WHERE JOB_ID = 17304;` obclient [oceanbase]> SELECT * FROM oceanbase.CDB_OB_BALANCE_JOB_HISTORY WHERE JOB_ID = 17304;`其中,
17304需要替换为上一步获取的BALANCE_JOB_ID。查询结果中的
STATUS列展示了BALANCE_JOB的执行状态:DOING:表示正在执行负载均衡工作。COMPLETED:表示负载均衡工作执行成功。CANCELING:表示负载均衡工作取消中。CANCELED:表示负载均衡工作已取消。
-
根据获取的
TRANSFER_TASK_ID查询视图CDB_OB_TRANSFER_TASKS或CDB_OB_TRANSFER_TASK_HISTORY,确认任务关联的 TRANSFER_TASK 的执行状态。视图
CDB_OB_TRANSFER_TASKS展示了所有租户当前正在执行的负载均衡任务。同一时间可能有多个负载均衡任务正在执行,这些任务(TRANSFER_TASK)都属于同一个负载均衡工作(BALANCE_JOB)。视图CDB_OB_TRANSFER_TASK_HISTORY展示了所有租户已执行的负载均衡任务历史。查询示例如下:obclient [oceanbase]> SELECT * FROM oceanbase.CDB_OB_TRANSFER_TASKS WHERE TASK_ID = 1;` obclient [oceanbase]> SELECT * FROM oceanbase.CDB_OB_TRANSFER_TASK_HISTORY WHERE TASK_ID = 1;`其中,
1需要替换为前面步骤中获取的TRANSFER_TASK_ID。查询结果中的
STATUS列展示了TRANSFER_TASK的执行状态:INIT:表示正在创建任务。START:表示开始执行 Transfer。DOING:表示正在执行 Transfer。ABORTED:表示 Transfer 任务执行失败,任务终止。COMPLETED:表示 Transfer 任务执行成功。FAILED:表示 Transfer 任务执行失败。CANCELED:表示 Transfer 任务取消。
-
-
根据获取的
TASK_ID查询视图CDB_OB_TRANSFER_PARTITION_TASK_HISTORY,确认 Transfer Partition 任务的结果。视图
CDB_OB_TRANSFER_PARTITION_TASK_HISTORY展示了所有租户已执行的 Transfer Partition 任务历史。obclient [oceanbase]> SELECT * FROM oceanbase.CDB_OB_TRANSFER_PARTITION_TASK_HISTORY WHERE TASK_ID = 1;其中,
1需要替换为前面步骤中获取的TASK_ID。查询结果中的
STATUS列展示了 Transfer Partition 任务的结果:COMPLETED:表示 Transfer Partition 任务执行成功。FAILED:表示 Transfer Partition 任务执行失败,可以通过COMMENT列进一步确认任务失败的原因。COMMENT列中常见的信息如下:LS not exist or may be in DROPPING/WAIT_OFFLINE status:Transfer 目的端的日志流可能不存在,或者处于DROPPING、WAITOFFLINE的状态。LS status is not NORMAL or is in BLOCK_TABLET_IN state:Transfer 目的端的日志流可能不是NORMAL的状态,例如,处于CREATING或CREATED等状态,或者日志流已经被BLOCK_TABLET_IN,不可以迁入。Table has beed dropped:待 Transfer 的分区所属的表被删除。Partition has beed dropped:待 Transfer 的分区被删除。Partition is already in dest LS:分区已经在 Transfer 目的端上。Need retry, partition may be dropped:在 Transfer 执行时,分区已经被删除了,系统会在下次生成负载均衡任务的时候重新检查确定分区是否存在。Need retry, partition may be dropped or be transferre:在 Transfer 执行时,分区不存在了,可能是由于分区被删除,或者分区不在源端日志流上了,系统会在下次生成负载均衡任务的时候排查分区是否存在或者需要重新生成 Transfer 任务。
-
Transfer Partition 任务执行成功后,再次查看对应的分区信息。
obclient [oceanbase]> SELECT TABLE_ID AS TABLE_ID, OBJECT_ID, TABLET_ID, LS_ID FROM oceanbase.CDB_OB_TABLE_LOCATIONS WHERE TENANT_ID = 1006 AND DATABASE_NAME = 'SYS' AND TABLE_NAME= 'TBL1_LOG_R' AND PARTITION_NAME = 'M202005' LIMIT 1;查询结果如下:
+----------+-----------+-----------+-------+ | TABLE_ID | OBJECT_ID | TABLET_ID | LS_ID | +----------+-----------+-----------+-------+ | 500003 | 500009 | 200006 | 1003 | +----------+-----------+-----------+-------+ 1 row in set根据结果可知,
SYS库下的表TBL1_LOG_R的M202005分区,从之前的1002号日志流迁移到了1003号日志流上,Transfer Partition 操作成功。
用户租户 Transfer Partition
MySQL 模式
Oracle 模式
本文档以租户 mysql_tenant 为例,提供操作指导。
-
MySQL 模式租户的租户管理员连接数据库。
连接示例如下,连接数据库时请以实际环境为准。
obclient -h10.xx.xx.xx -P2883 -uroot@mysql_tenant#obdemo -p***** -A -
确认分区信息。
查询视图
DBA_OB_TABLE_LOCATIONS,获取指定分区的TABLET_ID、OBJECT_ID以及LS_ID。-
获取非分区表的
TABLET_ID、OBJECT_ID以及LS_ID假设
mysql_tenant租户下存在非分区表t1,查询示例如下:obclient [test]> SELECT TABLE_ID AS TABLE_ID, OBJECT_ID, TABLET_ID, LS_ID FROM oceanbase.DBA_OB_TABLE_LOCATIONS WHERE DATABASE_NAME = 'test' AND TABLE_NAME= 't1' LIMIT 1;查询结果如下:
+----------+-----------+-----------+-------+ | TABLE_ID | OBJECT_ID | TABLET_ID | LS_ID | +----------+-----------+-----------+-------+ | 500002 | 500002 | 200001 | 1001 | +----------+-----------+-----------+-------+ 1 row in set -
获取一级分区表的
TABLET_ID、OBJECT_ID以及LS_ID对于一级分区表,查询时只需要指定具体的一级分区名即可。示例如下:
假设
mysql_tenant租户下存在一级分区表tbl1_l。obclient [test]> CREATE TABLE tbl1_l (col1 BIGINT PRIMARY KEY,col2 VARCHAR(50)) PARTITION BY LIST(col1) (PARTITION p0 VALUES IN (1, 2, 3), PARTITION p1 VALUES IN (5, 6), PARTITION p2 VALUES IN (DEFAULT) );查询该一级分区表中分区
p1相关信息的示例如下:obclient [oceanbase]> SELECT TABLE_ID AS TABLE_ID, OBJECT_ID, TABLET_ID, LS_ID FROM oceanbase.DBA_OB_TABLE_LOCATIONS WHERE DATABASE_NAME = 'test' AND TABLE_NAME= 'tbl1_l' AND PARTITION_NAME = 'p1' LIMIT 1;查询结果如下:
+----------+-----------+-----------+-------+ | TABLE_ID | OBJECT_ID | TABLET_ID | LS_ID | +----------+-----------+-----------+-------+ | 500012 | 500014 | 200009 | 1001 | +----------+-----------+-----------+-------+ 1 row in set -
获取二级分区表的
TABLET_ID、OBJECT_ID以及LS_ID对于二级分区表,查询时需要同时指定一级分区名和二级分区名。
假设
mysql_tenant租户下存在二级分区表t2_f_rclc。obclient [test]> CREATE TABLE t2_f_rclc (col1 INT,col2 INT) PARTITION BY RANGE COLUMNS(col1) SUBPARTITION BY LIST COLUMNS(col2) (PARTITION p0 VALUES LESS THAN(100) (SUBPARTITION sp0 VALUES IN(1,3), SUBPARTITION sp1 VALUES IN(4,6), SUBPARTITION sp2 VALUES IN(7,9)), PARTITION p1 VALUES LESS THAN(200) (SUBPARTITION sp3 VALUES IN(1,3), SUBPARTITION sp4 VALUES IN(4,6), SUBPARTITION sp5 VALUES IN(7,9)) );查询该二级分区表中二级分区
sp3相关信息的示例如下:obclient [oceanbase]> SELECT TABLE_ID AS TABLE_ID, OBJECT_ID, TABLET_ID, LS_ID FROM oceanbase.DBA_OB_TABLE_LOCATIONS WHERE DATABASE_NAME = 'test' AND TABLE_NAME= 't2_f_rclc' AND PARTITION_NAME = 'P1' AND SUBPARTITION_NAME = 'sp3' LIMIT 1;查询结果如下:
+----------+-----------+-----------+-------+ | TABLE_ID | OBJECT_ID | TABLET_ID | LS_ID | +----------+-----------+-----------+-------+ | 500003 | 500009 | 200005 | 1002 | +----------+-----------+-----------+-------+ 1 row in set
-
-
选择 Transfer 目的端。
-
查询视图
DBA_OB_LS,获取租户的日志流状态和信息。obclient [oceanbase]> SELECT * FROM oceanbase.DBA_OB_LS;查询结果如下:
+-------+--------+--------------+---------------+-------------+---------------------+----------+---------------------+---------------------+------+ | LS_ID | STATUS | PRIMARY_ZONE | UNIT_GROUP_ID | LS_GROUP_ID | CREATE_SCN | DROP_SCN | SYNC_SCN | READABLE_SCN | FLAG | +-------+--------+--------------+---------------+-------------+---------------------+----------+---------------------+---------------------+------+ | 1 | NORMAL | zone1 | 0 | 0 | NULL | NULL | 1701247658419109377 | 1701247658419109377 | | | 1001 | NORMAL | zone1 | 1003 | 1001 | 1701239750437064613 | NULL | 1701247658419109376 | 1701247658419109376 | | | 1002 | NORMAL | zone1 | 1004 | 1002 | 1701239750441114919 | NULL | 1701247658223204599 | 1701247658223204599 | | | 1003 | NORMAL | zone1 | 1005 | 1003 | 1701239750443869478 | NULL | 1701247659122731843 | 1701247659030755559 | | +-------+--------+--------------+---------------+-------------+---------------------+----------+---------------------+---------------------+------+ 4 rows in set -
查询视图
DBA_OB_TABLET_TO_LS,获取日志流上 Tablet 的分布信息。obclient [oceanbase]> SELECT LS_ID, COUNT(*) AS C FROM oceanbase.DBA_OB_TABLET_TO_LS GROUP BY LS_ID;查询结果如下:
+-------+------+ | LS_ID | C | +-------+------+ | 1 | 590 | | 1001 | 4 | | 1002 | 3 | | 1003 | 3 | +-------+------+ 4 rows in set根据上述展示的信息,选择合适的日志流作为 Transfer 目的端。
-
-
执行以下命令,进行 Transfer Partition 操作。
ALTER SYSTEM TRANSFER PARTITION TABLE_ID [=] table_id, OBJECT_ID [=] object_id TO LS ls_id;其中:
table_id:表 ID。object_id:分区的唯一标识。ls_id: Transfer 目的端的日志流 ID。tenant_name:待 Transfer 的分区所属的租户。
将租户
mysql_tenant内test库下的表tbl1_l的p1分区,从当前1001号日志流迁移到1003号日志流上,示例如下。obclient [oceanbase]> ALTER SYSTEM TRANSFER PARTITION TABLE_ID = 500012, OBJECT_ID = 500014 TO LS 1003; -
Transfer Partition 的命令执行成功后,可以通过以下视图查看任务状态。
-
查询视图
DBA_OB_TRANSFER_PARTITION_TASKS,获取任务的TASK_ID、TRANSFER_TASK_ID和BALANCE_JOB_ID。视图
DBA_OB_TRANSFER_PARTITION_TASKS展示了本租户下当前正在处理的 Transfer Partition 任务。查询示例如下:obclient [oceanbase]> SELECT TASK_ID, BALANCE_JOB_ID, TRANSFER_TASK_ID, STATUS FROM oceanbase.DBA_OB_TRANSFER_PARTITION_TASKS WHERE TABLE_ID = 500012 AND OBJECT_ID = 500014;查询结果的示例如下:
+---------+----------------+------------------+--------+ | TASK_ID | BALANCE_JOB_ID | TRANSFER_TASK_ID | STATUS | +---------+----------------+------------------+--------+ | 1 | 26506 | 1 | DOING | +---------+----------------+------------------+--------+ 1 row in set可以根据查询结果中
STATUS的值确认任务状态,进一步查看任务执行进度:WAITING: 表示任务在等待中,还没有开始调度。INIT:表示任务已经构建BALANCE_JOB了,您可以根据BALANCE_JOB_ID查看关联的BALANCE_JOB执行进度。DOING: 表示任务已经开始执行 Transfer 了,您可以根据TRANSFER_TASK_ID查看关联的 Transfer Partition 任务,TRANSFER_TASK_ID会变化很多次,一个 Transfer Partition 任务会涉及多次 Transfer。
如果视图
DBA_OB_TRANSFER_PARTITION_TASKS的查询结果为空,可以通过视图DBA_OB_TRANSFER_PARTITION_TASK_HISTORY来查看任务结果。 -
根据获取的
BALANCE_JOB_ID查询视图DBA_OB_BALANCE_JOBS或DBA_OB_BALANCE_JOB_HISTORY,确认关联的BALANCE_JOB的执行状态。视图
DBA_OB_BALANCE_JOBS展示了本租户当前正在执行的负载均衡工作。每个租户同一时间只有一个负载均衡工作(BALANCE_JOB),每个工作会生成多个负载均衡任务(TRANSFER_TASK)。视图DBA_OB_BALANCE_JOB_HISTORY展示了本租户已执行的负载均衡工作历史。查询示例如下:obclient [oceanbase]> SELECT * FROM oceanbase.DBA_OB_BALANCE_JOBS WHERE JOB_ID = 26506;` obclient [oceanbase]> SELECT * FROM oceanbase.DBA_OB_BALANCE_JOB_HISTORY WHERE JOB_ID = 26506;`其中,
26506需要替换为上一步获取的BALANCE_JOB_ID。查询结果中的
STATUS列展示了BALANCE_JOB的执行状态:DOING:表示正在执行负载均衡工作。COMPLETED:表示负载均衡工作执行成功。CANCELING:表示负载均衡工作取消中。CANCELED:表示负载均衡工作已取消。
-
根据获取的
TRANSFER_TASK_ID查询视图DBA_OB_TRANSFER_TASKS或DBA_OB_TRANSFER_TASK_HISTORY,确认任务关联的TRANSFER_TASK的执行状态。视图
DBA_OB_TRANSFER_TASKS展示了本租户当前正在执行的负载均衡任务。同一时间可能有多个负载均衡任务正在执行,这些任务(TRANSFER_TASK)都属于同一个负载均衡工作(BALANCE_JOB)。视图DBA_OB_TRANSFER_TASK_HISTORY展示了本租户已执行的负载均衡任务历史。查询示例如下:obclient [oceanbase]> SELECT * FROM oceanbase.DBA_OB_TRANSFER_TASKS WHERE TASK_ID = 1;` obclient [oceanbase]> SELECT * FROM oceanbase.DBA_OB_TRANSFER_TASK_HISTORY WHERE TASK_ID = 1;`其中,
1需要替换为前面步骤中获取的TRANSFER_TASK_ID。查询结果中的
STATUS列展示了TRANSFER_TASK的执行状态:INIT:表示正在创建任务。START:表示开始执行 Transfer。DOING:表示正在执行 Transfer。ABORTED:表示 Transfer 任务执行失败,任务终止。COMPLETED:表示 Transfer 任务执行成功。FAILED:表示 Transfer 任务执行失败。CANCELED:表示 Transfer 任务已取消。
-
-
根据获取的
TASK_ID查询视图DBA_OB_TRANSFER_PARTITION_TASK_HISTORY,确认 Transfer Partition 任务的结果。视图
DBA_OB_TRANSFER_PARTITION_TASK_HISTORY展示了本租户已执行的 Transfer Partition 任务历史。查询示例如下:obclient [oceanbase]> SELECT * FROM oceanbase.DBA_OB_TRANSFER_PARTITION_TASK_HISTORY WHERE TASK_ID = 1;其中,
1需要替换为前面步骤中获取的TASK_ID。查询结果中的
STATUS列展示了 Transfer Partition 任务的结果:COMPLETED:表示 Transfer Partition 任务执行成功。FAILED:表示 Transfer Partition 任务执行失败,可以通过COMMENT列进一步确认任务失败的原因。COMMENT列中常见的信息如下:LS not exist or may be in DROPPING/WAIT_OFFLINE status:Transfer 目的端的日志流可能不存在,或者处于DROPPING、WAITOFFLINE的状态。LS status is not NORMAL or is in BLOCK_TABLET_IN state:Transfer 目的端的日志流可能不是NORMAL的状态,例如,处于CREATING或CREATED等状态,或者日志流已经被BLOCK_TABLET_IN,不可以迁入。Table has beed dropped:待 Transfer 的分区所属的表被删除。Partition has beed dropped:待 Transfer 的分区被删除。Partition is already in dest LS:分区已经在 Transfer 目的端上。Need retry, partition may be dropped:在 Transfer 执行时,分区已经被删除了,系统会在下次生成负载均衡任务的时候重新检查确定分区是否存在。Need retry, partition may be dropped or be transferre:在 Transfer 执行时,分区不存在了,可能是由于分区被删除,或者分区不在源端日志流上了,系统会在下次生成负载均衡任务的时候排查分区是否存在或者需要重新生成 Transfer 任务。
-
Transfer Partition 任务执行成功后,再次查看对应的分区信息。
obclient [oceanbase]> SELECT TABLE_ID AS TABLE_ID, OBJECT_ID, TABLET_ID, LS_ID FROM oceanbase.DBA_OB_TABLE_LOCATIONS WHERE DATABASE_NAME = 'test' AND TABLE_NAME= 'tbl1_l' AND PARTITION_NAME = 'p1' LIMIT 1;查询结果如下:
+----------+-----------+-----------+-------+ | TABLE_ID | OBJECT_ID | TABLET_ID | LS_ID | +----------+-----------+-----------+-------+ | 500012 | 500014 | 200009 | 1003 | +----------+-----------+-----------+-------+ 1 row in set根据结果可知,
test库下的表tbl1_l的p1分区,从之前的1001号日志流迁移到了1003号日志流上,Transfer Partition 操作成功。




