`

用mysqlbinlog恢复MySQL数据库

阅读更多

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工具恢复删除的数据库记录.docx

    MySQLbinlog 是 MySQL 数据库管理系统中的一个重要工具,它允许用户查看和恢复数据库的二进制日志记录。 二进制日志记录是 MySQL 数据库中的一种日志记录方式,它记录了数据库中的所有操作,包括增删改查等。可以...

    怎么恢复mysql数据库/数据库丢失怎么处理

    然而,数据库的意外丢失或损坏可能带来严重的后果,因此掌握如何恢复MySQL数据库至关重要。本篇将详细介绍面对数据库丢失或损坏时的处理方法。 首先,了解MySQL数据库丢失或损坏的原因是关键。这可能源自硬件故障、...

    使用binlog日志恢复MySQL数据库删除数据的方法

    MySQL数据库的binlog日志是数据安全的重要保障,它记录了所有的DDL(Data Definition Language,如CREATE、ALTER、DROP等)和DML(Data Manipulation Language,如INSERT、UPDATE、DELETE等)语句,但不包括SELECT...

    mysql数据库备份与恢复

    本知识点将深入探讨如何在SpringBoot环境下对MySQL数据库进行备份与恢复,以确保数据的安全。 首先,`MysqlBackup.java` 文件很可能是实现备份和恢复功能的核心Java类。在SpringBoot中,我们可以利用JDBC(Java ...

    mysqlbinlog和binlog2sql的使用及mysql通过binlog日志恢复数据库数据

    mysqlbinlog和binlog2sql的使用及mysql通过binlog日志恢复数据库数据

    MySQL 数据库误删除后的数据恢复操作说明(详细)

    本文将详细介绍在遇到MySQL数据库误删除的情况下,如何通过备份文件和binlog文件进行数据恢复的操作流程。 #### 二、工作场景与背景 假设在某一典型的工作环境中,MySQL数据库被设置为每天晚上12点进行一次完全备份...

    Mysql数据库全量和增量备份

    2. 数据恢复:通过使用 mysqlbinlog 工具来使恢复数据。 binlog 日志的组成 binlog 日志包括两类文件: 1. 二进制日志索引文件(文件名后缀为.index):用于记录所有的二进制文件。 2. 二进制日志文件(文件名...

    mysqlbinlog工具详解

    mysqlbinlog工具是MySQL数据库中一个非常重要的工具,用于将二进制日志文件转换为SQL语句,以便于数据库的回复和恢复。mysqlbinlog工具的使用非常广泛,特别是在数据库出现故障或崩溃时,需要快速恢复数据库的数据。...

    MySQL利用binlog恢复库表

    当需要恢复被删除的数据时,可以使用`mysqlbinlog`工具查看相关的binlog日志文件,找到删除操作发生的时间点,然后恢复到该时间点之前的SQL操作。 1. **查找binlog日志文件**: 使用`mysqlbinlog`工具查看包含...

    mysqlbinlog.exe文件,win 7mysql 5.6下可用

    描述中提到的“phpStudy”是一个流行的PHP开发环境集成包,包含了Apache服务器、MySQL数据库和PHP等组件。然而,phpStudy默认可能并不包含`mysqlbinlog`工具,因此用户在尝试查看或操作二进制日志时可能会遇到问题。...

    Linux上通过binlog文件恢复mysql数据库详细步骤

    本文将详细阐述如何通过binlog文件恢复MySQL数据库的步骤。 首先,理解binlog的含义与作用至关重要。MySQL的binlog是一种记录所有改变数据库状态的非归档日志,包括插入、更新和删除操作。它不仅用于主从同步,确保...

    实验报告六 MYSQL备份与恢复.docx

    - 使用`mysqlbinlog`命令将二进制日志中的操作恢复到数据库。 - **示例命令**: - `mysqldump -u root -p --lock-tables=false database_name > database.sql`: 增量备份。 - `mysqlbinlog binlog_file | mysql -u...

    实验4 数据库备份与恢复实验 (2).docx

    图形化工具恢复是指使用图形化工具,如 MySQL Workbench,来恢复数据库中的数据。图形化工具恢复可以提供一个可视化的界面,以便恢复数据库中的数据。 知识点10: 实验总结 实验4 数据库备份与恢复实验旨在让学生...

    MySQL执行delete误删除数据恢复

    在MySQL数据库管理中,有时可能会不小心执行了DELETE命令,导致数据丢失。面对这种情况,有多种方法可以帮助恢复误删除的数据。本文将重点介绍如何利用MySQL的二进制日志(binlog)以及my2sql工具来恢复数据。 首先,...

    Windows下MySql数据库增量全量备份

    在Windows环境下,MySQL数据库的管理和维护是至关重要的任务,其中包括数据的安全备份与恢复。本教程将详细介绍如何利用`mysqldump`和`mysqlbinlog`工具进行全量备份、增量备份以及数据库的还原操作。 全量备份是...

    mysqlbinlog

    MySQLbinlog是MySQL数据库系统中的一个实用工具,用于读取、解析和输出二进制日志(Binary Log)内容。二进制日志是MySQL记录所有更改数据的...理解并熟练掌握mysqlbinlog的使用,对于MySQL数据库管理员来说至关重要。

    MySQL数据库:数据库日志管理.pptx

    在MySQL数据库中,日志管理是数据库管理和维护的重要组成部分。 首先,我们需要理解数据库日志的作用。数据库日志的主要功能包括: 1. **故障恢复**:当数据库发生故障时,通过日志可以追踪并恢复到故障发生前的...

    MySQL数据库日志管理.ppt

    使用二进制日志还原数据库可以使用mysqlbinlog工具从指定的时间点开始恢复的数据。可以暂时停止二进制日志功能通过SET SQL_LOG_BIN语句。 错误日志 错误日志记录MySQL服务的启动、运行或停止MySQL服务时出现的问题...

    MySQL 数据库误删除后的恢复方案

    MySQL 数据库误删除后的恢复方案是一项关键的故障应对策略,特别是在没有实时主从复制或热备的情况下。在本文中,我们将深入探讨如何利用备份数据文件和增量的 binlog(二进制日志)文件来恢复数据。 首先,开启 ...

Global site tag (gtag.js) - Google Analytics