PolarDB-X 1.0-SQL 手册-DDL任务管理-最佳实践

本文涉及的产品
云原生数据库 PolarDB 分布式版,标准版 2核8GB
简介: 本文将介绍一些对PENDING任务进行合适处理的最佳实践。

本文将介绍一些对PENDING任务进行合适处理的最佳实践。

背景介绍

新的DDL任务引擎启用时,当DDL执行失败或者被意外中断后,对应的DDL任务会处于PENDING待处理的状态,此时必须对该PENDING状态进行合适的任务处理,才能解除PENDING状态并恢复正常访问,否则后续的DDL将会被禁止执行并报错。

处理原则

  • 您可以通过SHOW [FULL] DDL语句查看DDL任务的信息和失败原因(即REMARK字段记录的异常信息)。
  • 您也可以参见如下常用的处理方式(建议您请根据实际情况选择最适合的方式):
  • 分析失败原因,修复或排除导致失败的因素(例如是由于数据问题导致的任务失败,则您可以通过去重等方式订正数据。如果是由于其它约束导致的失败,请确认是否能够去掉约束等)。修复完成后,使用RECOVER DDL恢复该PENDING 任务。
  • 如果导致失败的因素无法解除,并且DDL因失败而不能真正执行,您可以使用REMOVE DDL删除任务(务必确认DDL没有真正执行才可删除,否则可能造成不一致状态),删除后恢复可访问状态。
  • 如果您想直接删除DDL任务失败的表(比如表中无数据,可以直接删除重建),您可以使用REMOVE DDL删除任务,然后再执行DROP TABLE IF EXISTS删除表(务必确认表中无数据,或者数据可以丢弃,并且DROP TABLE一定要指定IF EXISTS语法,确保强制删除)。

示例

如下示例展示了对执行失败后处于PENDING状态的DDL任务进行处理的过程。

  1. 建表时没有指定主键,并且插入了带有重复值的数据行(ID=1有两行数据):
  1. mysql> create table test_pending (id intnotnull, age int) dbpartition by hash(id);
  2. Query OK,0 rows affected (0.33 sec)
  3. mysql> insert into test_pending values(1,10),(1,20),(2,20),(3,30);
  4. Query OK,4 rows affected (0.10 sec)
  5. mysql>select*from test_pending order by id;
  6. +------+------+
  7. | id   | age  |
  8. +------+------+
  9. |    1|   10|
  10. |    1|   20|
  11. |    2|   20|
  12. |    3|   30|
  13. +------+------+
  14. 4 rows inset(0.10 sec)
  1. 之后想为上述ID加上主键约束,但由于表中已有数据违反了唯一性约束,因此DDL执行失败:
  1. mysql> alter table test_pending add primary key (id);
  2. ERROR 4636(HY000):[f5be83373466000][10.81.69.55:3306][ddltest]ERR-CODE:[TDDL-4636][ERR_DDL_JOB_ERROR]Not all physical operations have been done successfully: expected 9,
  3. but done8.Causedby:1062:DDLTEST_1562056402230OYMK_7WW7_0001:Duplicate entry '1'for key 'PRIMARY' on `test_pending`;.
  1. 通过SHOW FULL DDL语句查看任务状态和失败原因,发现其中一个物理表中的数据有重复值导致了物理DDL执行失败:
  1. mysql> show full ddl\G
  2. ***************************1. row ***************************
  3.       JOB_ID:1106733441212637184
  4. PARENT_JOB_ID:0
  5.       SERVER:1:102:10.81.69.55
  6. OBJECT_SCHEMA: ddltest
  7.  OBJECT_NAME: test_pending
  8. NEW_OBJECT_NAME:
  9.     JOB_TYPE: ALTER_TABLE
  10.        PHASE: EXECUTE
  11.        STATE: PENDING
  12.     PROGRESS:77%
  13.   START_TIME:2019-09-0617:17:55.002
  14.     END_TIME:2019-09-0617:17:55.273
  15. ELAPSED_TIME(MS):271
  16.     DDL_STMT: alter table test_pending add primary key (id)
  17.       REMARK: ERR-CODE:[TDDL-4636][ERR_DDL_JOB_ERROR]Not all physical operations have been done successfully: expected 9, but done8.Causedby:1062:DDLTEST_1562056402
  18. 230OYMK_7WW7_0001:Duplicate entry '1'for key 'PRIMARY' on 'test_pending';.
  • REMARK字段中的详细信息解释如下:
  • Not all physical operations have been done successfully: expected 9, but done 8.:该逻辑表的DDL涉及到9个物理DDL的执行,完成了8个,有1个失败了,这个失败的物理DDL导致整个逻辑DDL失败,任务被置于PENDING状态。
  • Caused by: 1062:DDLTEST_1562056402 230OYMK_7WW7_0001:Duplicate entry '1' for key 'PRIMARY' on 'test_pending';:失败的根源在于DDLTEST_1562056402 230OYMK_7WW7_0001物理库的test_pending物理表中有ID字段的重复数据1,导致无法添加主键约束。
  1. 此时逻辑表处于不一致的状态:
  1. mysql> check table test_pending;
  2. +----------------------------------------+-------+----------+-------------------------------------------------------------------------------------------------------------+
  3. | TABLE                                  | OP    | MSG_TYPE | MSG_TEXT                                                                                                    |
  4. +----------------------------------------+-------+----------+-------------------------------------------------------------------------------------------------------------+
  5. | ddltest_1562056402230oymk.test_pending | check |Error    |Table'DDLTEST_1562056402230OYMK_7WW7_0001.test_pending' find incorrect columns 'id', please recreate table |
  6. +----------------------------------------+-------+----------+-------------------------------------------------------------------------------------------------------------+
  7. 1 row inset(0.04 sec)
  1. 执行其它 DDL 也会被禁止,收到相应的错误:
  1. mysql> drop table test_pending;
  2. ERROR 4644(HY000):[f5beae39d466000][10.81.69.55:3306][ddltest]ERR-CODE:[TDDL-4644][ERR_PENDING_DDL_JOB_EXISTS]Another DDL job '1106733441212637184'with operation 'ALTER_
  3. TABLE'is pending on ddltest.test_pending in ddltest.Pleaseuse SHOW DDL to check it,andthen recover or rollback it using RECOVER DDL or ROLLBACK DDL,or just remove it us
  4. ing REMOVE DDL if you confirm that the pending job can be discarded.
  1. 接下来,根据前面所述的常见的处理方式,有如下几种选择进行继续处理(分别展示它们的效果):
  • 去重(删除重复的数据)后,恢复DDL任务,继续完成添加主键约束的操作
  1. 删除重复数据(根据业务需要,仅保留一条数据),删除数据操作可以通过PolarDB-X执行,也可以根据报错信息,直接连接到PolarDB-X后端的RDS物理库中操作:
  1. mysql>deletefrom test_pending where id=1and age=20;
  2. Query OK,1 row affected (0.07 sec)
  3. mysql>select*from test_pending order by id;
  4. +------+------+
  5. | id   | age  |
  6. +------+------+
  7. |    1|   10|
  8. |    2|   20|
  9. |    3|   30|
  10. +------+------+
  11. 3 rows inset(0.02 sec)
  1. 确认表中已经没有重复数据后,恢复之前PENDING的DDL任务的执行(恢复成功,完成的任务被自动清理,主键添加成功):
  1. mysql> recover ddl 1106733441212637184;
  2. Query OK,0 rows affected (1.28 sec)
  3. mysql> show full ddl\G
  4. Emptyset(0.00 sec)
  5. mysql> show create table test_pending\G
  6. ***************************1. row ***************************
  7. Table: test_pending
  8. CreateTable: CREATE TABLE `test_pending`(
  9. `id`int(11) NOT NULL,
  10. `age`int(11) DEFAULT NULL,
  11. PRIMARY KEY (`id`),
  12. KEY `auto_shard_key_id`(`id`) USING BTREE
  13. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 dbpartition by hash(`id`)
  14. 1 row inset(0.02 sec)
  15. mysql> check table test_pending;
  16. +----------------------------------------+-------+----------+----------+
  17. | TABLE                                  | OP    | MSG_TYPE | MSG_TEXT |
  18. +----------------------------------------+-------+----------+----------+
  19. | ddltest_1562056402230oymk.test_pending | check | status   | OK       |
  20. +----------------------------------------+-------+----------+----------+
  21. 1 row inset(0.10 sec)
  • 直接删除任务,然后删除表(测试数据可以丢弃),后续再根据需要重新创建该表
  1. mysql> remove ddl 1106733441212637184;
  2. Query OK,1 row affected (0.02 sec)
  3. mysql> drop table if exists test_pending;
  4. Query OK,0 rows affected (0.44 sec)
  5. mysql> show tables like 'test_pending';
  6. Emptyset(0.01 sec)
相关实践学习
快速体验PolarDB开源数据库
本实验环境已内置PostgreSQL数据库以及PolarDB开源数据库:PolarDB PostgreSQL版和PolarDB分布式版,支持一键拉起使用,方便各位开发者学习使用。
相关文章
|
29天前
|
SQL 开发框架 .NET
ASP.NET连接SQL数据库:详细步骤与最佳实践指南ali01n.xinmi1009fan.com
随着Web开发技术的不断进步,ASP.NET已成为一种非常流行的Web应用程序开发框架。在ASP.NET项目中,我们经常需要与数据库进行交互,特别是SQL数据库。本文将详细介绍如何在ASP.NET项目中连接SQL数据库,并提供最佳实践指南以确保开发过程的稳定性和效率。一、准备工作在开始之前,请确保您
137 3
|
2月前
|
存储 关系型数据库 分布式数据库
GraphRAG:基于PolarDB+通义千问+LangChain的知识图谱+大模型最佳实践
本文介绍了如何使用PolarDB、通义千问和LangChain搭建GraphRAG系统,结合知识图谱和向量检索提升问答质量。通过实例展示了单独使用向量检索和图检索的局限性,并通过图+向量联合搜索增强了问答准确性。PolarDB支持AGE图引擎和pgvector插件,实现图数据和向量数据的统一存储与检索,提升了RAG系统的性能和效果。
|
4月前
|
SQL 存储 关系型数据库
关系型数据库SQLserver基本 SQL 操作
【7月更文挑战第28天】
35 4
|
1月前
|
SQL 存储 数据库
SQL语句给予用户权限:技巧、方法与最佳实践
在数据库管理中,为用户分配适当的权限是确保数据安全性和操作效率的关键步骤
|
1月前
|
SQL 数据管理 数据库
文章初学者指南:SQL新建数据库详细步骤与最佳实践
引言:在当今数字化的世界,数据库管理已经成为信息技术领域中不可或缺的一部分。作为广泛使用的数据库管理系统,SQL已经成为数据管理和信息检索的标准语言。本文将详细介绍如何使用SQL新建数据库,包括准备工作、具体步骤和最佳实践,帮助初学者快速上手。一、准备工作在开始新建数据库之前,你需要做好以下准备工作
110 3
|
1月前
|
存储 关系型数据库 分布式数据库
GraphRAG:基于PolarDB+通义千问+LangChain的知识图谱+大模型最佳实践
本文介绍了一种结合知识图谱与大型语言模型(LLM)的GraphRAG系统,利用PolarDB、通义千问及LangChain实现。知识图谱通过结构化信息、语义理解和推理等功能,增强了信息检索与自然语言处理效果。PolarDB具备图引擎与向量检索能力,适配知识图谱存储与查询。通义千问处理自然语言,LangChain则整合模型与应用。实战步骤包括环境准备、数据库配置与数据导入,并通过实例展示了图谱与向量联合检索的优越性,提升了问答系统的准确性和实用性。
|
3月前
|
监控 关系型数据库 分布式数据库
PolarDB 读写分离的最佳实践
【8月更文第27天】PolarDB 是阿里云推出的一款高度兼容 MySQL、PostgreSQL 和 Oracle 的云原生数据库服务。它支持读写分离,能够显著提高应用的性能和响应速度。本文将详细介绍如何在 PolarDB 中实施读写分离策略,并通过示例代码演示具体的配置步骤。
112 1
|
3月前
|
SQL 安全 关系型数据库
关系型数据库SQL server DELETE 语句
【8月更文挑战第3天】
76 10
|
3月前
|
SQL 关系型数据库 数据库
关系型数据库SQL server UPDATE 语句
【8月更文挑战第3天】
68 10
|
3月前
|
SQL 关系型数据库 BI
关系型数据库SQL server INSERT 语句
【8月更文挑战第3天】
61 9

相关产品

  • 云原生分布式数据库 PolarDB-X
  • 下一篇
    无影云桌面