百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

MySQL 数据库恢复:如何执行时间点恢复(PITR)以挽救受损数据?

wptr33 2025-06-28 17:11 20 浏览

天津鸿萌科贸发展有限公司从事数据安全服务二十余年,致力于为各领域客户提供专业的数据恢复、数据备份、数据取证、数据迁移、网络安全、数据清除等解决方案,并针对企业面临的数据安全风险,提供专业的相关数据安全培训。

天津鸿萌科贸发展有限公司是众多国际主流数据取证、数据恢复、数据备份及同步软件的授权代理商:Miray(HDClone/HDShredder)、Killdisk、Passware、PassMark、ElcomSoft、R-Studio、Systools、GetData、Stellar、ReclaiMe、UFS Explorer、VNR、SyncBack Pro、ViceVersa Pro 等。

时间点恢复(PITR)是一种基于备份的恢复类型,首先将完整备份进行还原,然后再将数据更改还原到某一指定的时刻。基于二进制日志记录,它可以将数据库还原到问题发生之前较邻近的时间。

我们举例说明一下:

如果您的 MySQL 服务器在星期二下午 3 点突然遇到系统崩溃,导致数据库中的表损坏。您可以将数据库还原到崩溃发生之前最邻近的那一时间点。如果启用了二进制日志记录,则可以执行时间点恢复到崩溃发生之前的状态。

但是,要使用 PITR 还原数据库,您必须具有二进制日志文件。只有在完全备份后才会创建这些文件。完全备份后对数据库所做的所有更改都记录在这些二进制日志文件中。这些文件通常出现在一系列备份的最后一个增量备份中。

在本文中,我们将学习如何执行时间点恢复以恢复 MySQL 数据库的不同方法。

MySQL 中时间点恢复的先决条件

对于 MySQL Server 中的时间点恢复,需考虑以下事项:

  • 默认情况下,二进制日志文件存在于备份文件中。但是,如果使用 –use-tts 选项创建了备份,则不会生成二进制日志文件。
  • 确保有一个可读的完整备份文件。二进制日志文件通常包含在增量备份文件中,可以将其用于时间点恢复。
  • 确保已启用 Binary logging (二进制日志记录)。
  • 确保拥有恢复备份的所有权限。可以执行 SHOW PRIVELEGES 语句来检查权限。

执行时间点恢复以还原数据库的方法

可以使用以下方法执行时间点恢复。

方法 1:使用二进制日志(Binlog)文件

二进制日志文件包含在最后一个备份文件中。它包含记录数据库更改的事件。它描述了对表数据的修改和创建表的操作。它包括用户进行更改所使用的 DELETE 语句。它还包含更新数据库中的数据所采用的语句的持续时间。

使用二进制日志文件执行时间点恢复的步骤:

首先,确保在 MySQL Server 上启用了二进制日志记录。要检查二进制日志记录的状态,可以执行以下命令:

mysql> SHOW VARIABLES LIKE 'log_bin';

如果 log_bin file 的值显示为 ON,则表示已启用二进制日志记录。现在,按照以下步骤从二进制日志中恢复数据:

  • 查找当前二进制日志文件的名称和位置。默认情况下,二进制日志文件位于 data 目录中。但是,可以使用 –log-bin 选项将这些文件放在其他位置。可以运行以下语句来查看所有二进制日志文件的列表:
mysql> SHOW BINARY LOGS;
  • 如果想了解服务器上二进制日志文件的状态,请运行以下命令:
mysql> SHOW BINARY LOG STATUS;
  • 要在 MySQL Server 上查找当前二进制日志文件的名称,可以运行以下命令:
mysql> SHOW MASTER STATUS;
  • 接下来,使用 mysqlbinlog 实用程序重放二进制日志事件。确保您拥有执行日志事件的所有权限,例如 BINLOG_ADMIN 权限或 SUPER、REPLICATIION_APPLIER。这是运行 mysqlbinlog 实用程序的命令:
mysqlbinlog [options] log_file

注意:执行上述命令时,可以查看文本格式的二进制日志文件中的事件。

  • 可以检查二进制日志文件中的数据,并选择要应用的某个内容。运行以下命令:
gt; mysql -u root -p < tmpfile

或者,您可以使用以下命令直接从二进制日志文件应用事件:

gt; mysqlbinlog binlog_files | mysql -u root -p
  • 接下来,使用以下命令通过 binlog 文件恢复 MySQL 数据库:
mysqlbinlog | mysql -u -p
  • 要使用多个 binlog 文件恢复 MySQL 数据库,请运行以下命令:
mysqlbinlog mysql_bin.000001 mysql_bin.000002 | mysql -u root -ppassword database_name

方法 2:使用事件位置

您还可以使用二进制日志中的事件位置在 MySQL 中执行时间点恢复。在这种情况下,必须精确检查二进制日志以了解确切的位置和事件,然后使用它来应用二进制日志事件。可以使用 mysqlbinlog 程序检查事件位置。

使用事件位置执行时间点恢复的步骤:

  • 首先恢复最后一个完整备份以及一系列相关备份。
  • 接下来,使用 mysqlbinlog 查找与时间点对应的二进制日志事件位置。使用--start-position--stop-position 选项:
mysqlbinlog --start-position="binary-log-position-at-the-end-of-backup-restores" \
         --stop-position="binary-log-position-corresponding-to-tR" \
         binary-log-filename  |   mysql -uadmin -p
  • 接下来,从该位置开始将二进制日志事件应用于服务器。
gt; mysqlbinlog --start-position=1006 --stop-position=1868 /var/lib/mysql/bin.123456 \
         | mysql -u root -p

此命令将重复在指定时间点之前对数据库所做的所有更改。它将恢复从起始位置恢复到停止位置之间的所有事务。将损坏的数据库恢复到 MySQL 数据库崩溃之前的目标时间点。

时间点恢复的限制

MySQL 时间点恢复功能可以帮助用户将损坏的数据库恢复到过去的特定时刻。但是,它需要启用二进制日志记录功能并需要有最近的可读备份。如果二进制日志文件损坏,则时间点恢复可能会失败。

使用专业的 MySQL 数据库恢复工具,自行恢复受损数据库

如果备份文件或二进制日志文件已损坏或禁用了二进制日志记录,用户可以使用专门的 MySQL 恢复工具来恢复受损的 MySQL 数据库。专业的 MySQL 恢复工具可以快速从损坏的数据库中恢复数据。可以修复在 InnoDB 和 MyISAM 存储引擎中创建的受损数据库。这类工具可以完全精确地将所有数据从损坏的数据库恢复到新数据库。用户还可以将修复后的数据库文件保存为 MariaDB、SQL Script、CSV、XLS 和 HTML 等多种格式。

委托专业的 MySQL 数据库恢复专家,安全地恢复受损数据库

发生数据安全事件时,及时寻求数据恢复专家的建议是可靠的办法,可以快速地恢复重要数据,避免自行操作造成进一步的数据损失。

相关推荐

MySQL进阶五之自动读写分离mysql-proxy

自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...

Postgres vs MySQL_vs2022连接mysql数据库

...

3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?

引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...

一文由浅入深带你完全掌握MySQL的锁机制原理与应用

本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...

验证Mysql中联合索引的最左匹配原则

后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...

MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)

目录1.索引基础...

你会看 MySQL 的执行计划(EXPLAIN)吗?

SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...

MySQL 从入门到精通(四)之索引结构

索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...

mysql总结——面试中最常问到的知识点

mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...

mysql总结——面试中最常问到的知识点(2)

首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...

MySQL基础全知全解!超详细无废话!轻松上手~

本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...

深入剖析 MySQL 中的锁机制原理_mysql 锁详解

在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...

Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析

引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...

MySQL基础篇:DQL数据查询操作_mysql 查

一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...

MySql:索引的基本使用_mysql索引的使用和原理

一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...