本文介绍了SQL闪回功能的使用方法。
背景介绍
PolarDB-X SQL闪回功能针对SQL误操作,提供行级数据的恢复能力。
当您在PolarDB-X上执行误操作SQL(如INSERT、UPDATE或DELETE) 后,使用SQL闪回,提供相关的误操作信息,即可从Binlog中找到匹配的事件,生成对应的恢复文件,下载后根据需求恢复数据。
SQL闪回针对误操作SQL,支持模糊匹配与精确匹配两种丢失数据的定位策略,以及自动选择匹配策略的能力,请参见精确匹配与模糊匹配。
面向不同的使用场景,SQL闪回提供回滚SQL与原始SQL两种方式来恢复数据。
功能优势
- 操作简单:轻松配置,填写少量误操作SQL信息,即可助您找回丢失的数据。
- 灵活的恢复方式:针对不同的场景,提供回滚SQL与原始SQL两种能力,恢复方式灵活多样。
- SQL级精确匹配能力:SQL级的误操作数据精确匹配能力,提高数据恢复的精准性。
限制与说明
- SQL闪回生成的恢复文件默认保存7天,生成后请尽快下载。
- SQL闪回精确匹配需要满足如下条件:
- 执行误操作SQL前,SQL闪回精确匹配能力已开启。
- 提供误操作SQL的TRACE_ID信息。
生成恢复文件
定位误操作SQL
- 在控制台上选择说明 如果您未开启SQL审计,请参见开启SQL审计与分析进行操作。
。
- 使用SQL审计与分析,定位误操作SQL的审计记录。关于如何快速定位误操作SQL,请参见日志分析。
- 获取误操作SQL数据中的
sql_time
、table_name
、sql_type
和trace_id
字段。
精确匹配与模糊匹配
SQL闪回根据您提供的误操作SQL信息,在Binlog中查找对应的匹配事件,反向生成对应的恢复SQL。受实例版本、参数设置的影响,SQL闪回支持两种Binlog事件的匹配策略:精确匹配与模糊匹配。具体的匹配策略无需选择,当未提供TRACE_ID时为模糊匹配,当提供了TRACE_ID且您的实例具备精确匹配能力时为精确匹配,否则会降级为模糊匹配。PolarDB-X SQL闪回会自动检测,选择最优的匹配策略,并在闪回任务结束后通知您。
精确匹配针对误操作SQL,在Binlog中精确匹配出该SQL误操作的事件,生成恢复文件。
优点:恢复文件中仅包含误操作SQL误删(误改)的数据,可直接使用,保证数据恢复的精准性与效率。
- PolarDB-X实例版本在5.3.4-15378085版本及以上。
- 执行误操作SQL前,SQL闪回精确匹配开关已开启。开启SQL精确匹配开关后,Binlog中会默认带上执行SQL的信息,增加一定的存储空间。
- 提供误操作SQL的TRACE_ID信息。
针对误操作SQL的相关信息(执行时间范围、操作表名、SQL类型等),在Binlog中匹配满足条件的事件,生成对应的恢复文件。
优点:不依赖实例版本、参数设置等,所有实例都支持。
缺点:无法精准匹配误删(误改)的数据,恢复文件中包含其它业务SQL改动的数据,需要您从中筛选出所需数据。
开启精确匹配
- 登录云原生分布式数据库控制台,前往指定实例的参数设置页面,详情请参见参数设置。
- 确保binlog_rows_query_log_events参数值为ON(默认为ON)。
回滚SQL与原始SQL
为了支持不同的业务场景,PolarDB-X SQL闪回提供生成回滚SQL与生成原始SQL两种恢复方式,您在生成恢复SQL文件前,需要根据使用场景,选择对应的恢复方式。
逆序遍历Binlog中的匹配事件,对INSERT、UPDATE、DELETE事件进行逆反操作,生成的SQL。
- INSERT逆反等价于DELETE。
- DELETE逆反等价于REPLACE。
- UPDATE逆反等价于UPDATE SET value=变更前。
使用方式:在原表执行,对现有数据进行覆盖性恢复。
适用场景:当需要恢复的数据没有冲突或者接受部分冲突数据被覆盖,建议生成回滚SQL。
原始SQL顺序遍历Binlog中的匹配事件,对INSERT、UPDATE、DELETE事件进行全记录的镜像构造处理,生成的SQL。
- INSERT镜像等价于INSERT。
- DELETE镜像等价于INSERT。
- UPDATE镜像等价于INSERT变更前的值。
使用方式:在临时表执行,写入误操作前的原始数据,与现有数据进行对比,分析冲突后决定最终数据。
适用场景:当需要恢复的数据与当前数据存在冲突时,建议生成原始SQL。