http://www.rongsen.com.cn/article/MySQL/2011/0724/5151.html
如果MySQL
服务器
启用了二进制日志,
你可以使用mysql
binlog工具来恢复从指定的时间点开始 (例如,
从你最后一次备份)直到现在或另一个指定的时间点的数据。
关于启用二进制日志的信息,参见5.11.3节,“二进制日志”。
对于 mysql
binlog的详细信息,参见mysql手册8.6节,“mysqlbinlog:用于处理二进制日志文件的实用工具”。
要想从二进制日志恢复数据,你需要知道当前二进制日志文件的路径和文件名。一般可以从选项文件(即my.cnf or my.ini,取决于你的系统)中找到路径。如果未包含在选项文件中,当服务器
启动时,可以在命令行中以选项的形式给出。启用二进制日志的选项为-- log-bin。要想确定当前的二进制日志文件的文件名,输入下面的MySQL
语句:
SHOW BINLOG EVENTS G
你还可以从命令行输入下面的内容:
mysql --user=root -pmy_pwd -e 'SHOW BINLOG EVENTS G'
将密码my_pwd替换为服务器的root密码。
1. 指定恢复时间
对于MySQL
4.1.4,可以在mysqlbinlog语句中通过--start-date和--stop-date选项指定DATETIME格式的起止时间。举例说
明,假设在今天上午10:00(今天是2005年4月20日),执行SQL语句来删除一个大表。要想恢复表和数据,你可以恢复前晚上的备份,并输入:
mysqlbinlog --stop-date="2005-04-20 9:59:59" /var/log/mysql/bin.123456
| mysql -u root -pmypwd
该命令将恢复截止到在--stop-date选项中以DATETIME格式给出的日期和时间的所有数据。如果你没有检测到几个小时后输入的错误的SQL语句,可能你想要恢复后面发生的活动。根据这些,你可以用起使日期和时间再次运行mysqlbinlog:
mysqlbinlog --start-date="2005-04-20 10:01:00" /var/log/mysql/bin.123456
| mysql -u root -pmypwd
在该行中,从上午10:01登录的SQL语句将运行。组合执行前夜的转储文件和mysqlbinlog的两行可以将所有数据恢复
到上午10:00前一秒钟。你应检查日志以确保时间确切。下一节介绍如何实现。
2. 指定恢复位置
也可以不指定日期和时间,而使用mysqlbinlog的选项--start-position和--stop-position来指定日志位置。它们的
作用与起止日选项相同,不同的是给出了从日志起的位置号。使用日志位置是更准确的恢复方法,特别是当由于破坏性SQL语句同时发生许多事务的时候。要想确
定位置号,可以运行mysqlbinlog寻找执行了不期望的事务的时间范围,但应将结果重新指向文本文件以便进行检查。操作方法为:
mysqlbinlog --start-date="2005-04-20 9:55:00" --stop-date="2005-04-20 10:05:00"
/var/log/mysql/bin.123456 > /tmp/mysql_restore.sql
该命令将在/tmp目录创建小的文本文件,将显示执行了错误的SQL语句时的SQL语句。你可以用文本编辑器打开该文件,寻找你不要想重复的语句。如果二
进制日志中的位置号用于停止和继续恢复操作,应进行注释。用log_pos加一个数字来标记位置。使用位置号恢复了以前的备份文件后,你应从命令行输入下
面内容:
mysqlbinlog --stop-position="368312" /var/log/mysql/bin.123456
| mysql -u root -pmypwd
mysqlbinlog --start-position="368315" /var/log/mysql/bin.123456
| mysql -u root -pmypwd
上面的第1行将恢复到停止位置为止的所有事务。下一行将恢复从给定的起始位置直到二进制日志结束的所有事务。因为mysqlbinlog的输出包括每个SQL语句记录之前的SET TIMESTAMP语句,恢复的数据和相关MySQL日志将反应事务执行的原时间。
分享到:
相关推荐
MySQLbinlog 是 MySQL 数据库管理系统中的一个重要工具,它允许用户查看和恢复数据库的二进制日志记录。 二进制日志记录是 MySQL 数据库中的一种日志记录方式,它记录了数据库中的所有操作,包括增删改查等。可以...
然而,数据库的意外丢失或损坏可能带来严重的后果,因此掌握如何恢复MySQL数据库至关重要。本篇将详细介绍面对数据库丢失或损坏时的处理方法。 首先,了解MySQL数据库丢失或损坏的原因是关键。这可能源自硬件故障、...
MySQL数据库的binlog日志是数据安全的重要保障,它记录了所有的DDL(Data Definition Language,如CREATE、ALTER、DROP等)和DML(Data Manipulation Language,如INSERT、UPDATE、DELETE等)语句,但不包括SELECT...
本知识点将深入探讨如何在SpringBoot环境下对MySQL数据库进行备份与恢复,以确保数据的安全。 首先,`MysqlBackup.java` 文件很可能是实现备份和恢复功能的核心Java类。在SpringBoot中,我们可以利用JDBC(Java ...
mysqlbinlog和binlog2sql的使用及mysql通过binlog日志恢复数据库数据
本文将详细介绍在遇到MySQL数据库误删除的情况下,如何通过备份文件和binlog文件进行数据恢复的操作流程。 #### 二、工作场景与背景 假设在某一典型的工作环境中,MySQL数据库被设置为每天晚上12点进行一次完全备份...
2. 数据恢复:通过使用 mysqlbinlog 工具来使恢复数据。 binlog 日志的组成 binlog 日志包括两类文件: 1. 二进制日志索引文件(文件名后缀为.index):用于记录所有的二进制文件。 2. 二进制日志文件(文件名...
mysqlbinlog工具是MySQL数据库中一个非常重要的工具,用于将二进制日志文件转换为SQL语句,以便于数据库的回复和恢复。mysqlbinlog工具的使用非常广泛,特别是在数据库出现故障或崩溃时,需要快速恢复数据库的数据。...
当需要恢复被删除的数据时,可以使用`mysqlbinlog`工具查看相关的binlog日志文件,找到删除操作发生的时间点,然后恢复到该时间点之前的SQL操作。 1. **查找binlog日志文件**: 使用`mysqlbinlog`工具查看包含...
描述中提到的“phpStudy”是一个流行的PHP开发环境集成包,包含了Apache服务器、MySQL数据库和PHP等组件。然而,phpStudy默认可能并不包含`mysqlbinlog`工具,因此用户在尝试查看或操作二进制日志时可能会遇到问题。...
本文将详细阐述如何通过binlog文件恢复MySQL数据库的步骤。 首先,理解binlog的含义与作用至关重要。MySQL的binlog是一种记录所有改变数据库状态的非归档日志,包括插入、更新和删除操作。它不仅用于主从同步,确保...
- 使用`mysqlbinlog`命令将二进制日志中的操作恢复到数据库。 - **示例命令**: - `mysqldump -u root -p --lock-tables=false database_name > database.sql`: 增量备份。 - `mysqlbinlog binlog_file | mysql -u...
图形化工具恢复是指使用图形化工具,如 MySQL Workbench,来恢复数据库中的数据。图形化工具恢复可以提供一个可视化的界面,以便恢复数据库中的数据。 知识点10: 实验总结 实验4 数据库备份与恢复实验旨在让学生...
在MySQL数据库管理中,有时可能会不小心执行了DELETE命令,导致数据丢失。面对这种情况,有多种方法可以帮助恢复误删除的数据。本文将重点介绍如何利用MySQL的二进制日志(binlog)以及my2sql工具来恢复数据。 首先,...
在Windows环境下,MySQL数据库的管理和维护是至关重要的任务,其中包括数据的安全备份与恢复。本教程将详细介绍如何利用`mysqldump`和`mysqlbinlog`工具进行全量备份、增量备份以及数据库的还原操作。 全量备份是...
MySQLbinlog是MySQL数据库系统中的一个实用工具,用于读取、解析和输出二进制日志(Binary Log)内容。二进制日志是MySQL记录所有更改数据的...理解并熟练掌握mysqlbinlog的使用,对于MySQL数据库管理员来说至关重要。
在MySQL数据库中,日志管理是数据库管理和维护的重要组成部分。 首先,我们需要理解数据库日志的作用。数据库日志的主要功能包括: 1. **故障恢复**:当数据库发生故障时,通过日志可以追踪并恢复到故障发生前的...
使用二进制日志还原数据库可以使用mysqlbinlog工具从指定的时间点开始恢复的数据。可以暂时停止二进制日志功能通过SET SQL_LOG_BIN语句。 错误日志 错误日志记录MySQL服务的启动、运行或停止MySQL服务时出现的问题...
MySQL 数据库误删除后的恢复方案是一项关键的故障应对策略,特别是在没有实时主从复制或热备的情况下。在本文中,我们将深入探讨如何利用备份数据文件和增量的 binlog(二进制日志)文件来恢复数据。 首先,开启 ...