数据追踪

更新时间: 2023-09-20 11:10:19

数据追踪功能可以快速按需找到目标时间段内的相关更新信息,并生成逆向回滚语句。本文介绍如何使用数据追踪功能。

背景信息

在日常访问数据库时,可能由于误更新、误删除、误写入等原因导致数据不符合预期,需要将数据快速恢复到正常状态。常规的方案可能为搭建克隆实例、实例恢复、库恢复、表恢复,其中库恢复、表恢复依赖于对库、表进行细粒度的备份管理,不仅成本较高,且需要事先制定备份方案。

数据管理DMS提供的数据追踪功能可以快速按需找到目标时间段内的相关更新,汇总生成逆向的回滚语句,追踪完的数据可批量生成回滚脚本,通过数据变更工单最终执行到数据库中完成数据的修复。

前提条件

  • 数据库类型为MySQL,且MySQL为5.6及以上版本。

    说明

    包含RDS MySQLPolarDB MySQL版、ECS上自建、本地IDC自建、其他云厂商的云数据库、其他云厂商的云服务器自建等已接入DMS企业版统一管理的MySQL。

  • 数据库已开启Binlog。

  • 数据库已登录。
    说明 管控模式为自由操作与稳定变更的数据库实例需要先登录,安全协同的数据库实例请忽略,更多关于管控模式的信息,请参见管控模式

注意事项

  • 自由操作模式的实例:支持追踪30分钟内进行的DML操作,且无法导出回滚、重建脚本。

  • 稳定变更、安全协同模式的实例:无查询时间限制,可批量下载脚本。

操作步骤

  1. 登录数据管理DMS 5.0
  2. 在顶部菜单栏中,选择数据库开发 > 数据追踪工单 > 数据追踪

    说明

    若您使用的是极简模式的控制台,请单击控制台左上角的2023-01-28_15-57-17.png图标,选择全部功能 > 数据库开发 > 数据追踪工单 > 数据追踪

  3. 在页面右上角,单击数据追踪

  4. 数据追踪工单申请页面,配置如下信息:

    参数名

    说明

    任务名称

    便于后续检索,并提供给审批人员清晰的操作意图。

    库名

    指定数据库实例上某个具体数据库(需要在DMS内有数据库的操作权限,输入库名前缀后可出现联想提示)。

    表名

    在指定的目标表中进行检索,支持添加多张表。

    追踪类型

    支持多选,可按需选中检索的操作。

    • 插入:插入类型的回滚语句为DELETE

    • 更新:更新类型的回滚语句为UPDATE

    • 删除:删除类型的回滚语句为INSERT

    时间范围

    选择追踪的时间范围。

    • 管控模式为自由操作的实例,仅支持追踪30分钟范围内的数据。

    • 管控模式为稳定变更和安全协同的实例不限制数据范围,在一个工单中最多可选择48小时,若超过48小时可分段提交多次工单。

    变更相关人

    可按需选择,非工单参与人、审批人,不可见工单详情。

  5. 单击提交申请,系统将获取日志文件。

    获取日志文件后,系统会进入审批环节。

    说明

    若Binlog未开启或数据库未登录,系统将无法获取日志文件。

  6. 等待审批通过。

    说明

    目前,数据追踪的默认安全审批规则为数据库对应的DBA进行审批。更多关于数据追踪的审批规则请参见数据追踪安全规则

  7. 审批通过后,系统会进行日志下载、日志解析等操作。

  8. 待解析完成后,您可以勾选需要回滚的变更记录,单击导出回滚脚本即可。

    您还可以进行如下操作:

    • 勾选多条记录,批量导出,默认每页显示10条,最多显示单页200条,您可以按需选择。

    • 单击目标记录右侧的查看详情按钮,查看明细以及拷贝对应回滚语句。

    • 追踪类型栏中进行筛选,快速筛选插入更新删除类型的记录。

后续步骤

导出回滚脚本后,您可以提交普通数据变更工单,将此回滚脚本作为附件上传至工单中,执行至目标数据库中。更多信息,请查看普通数据变更

阿里云首页 数据管理 DMS 相关技术圈