mysql数据如何通过data文件恢复

目录
  • mysql数据通过data文件恢复
  • mysql数据恢复方法个人总结
    • 步骤
    • 其它笔记
  • 总结

mysql数据通过data文件恢复

mysql磁盘文件被损坏,无法启动,能看到data文件,在没有备份的话如何复原?

情景1:知道数据库中的表结构

1、先执行表结构语句

2、解除绑定

alter table `表1`  discard  tablespace;
alter table `表2`  discard  tablespace;
......

此时当前数据库下所有的.idb文件都会被删除,也就是只剩下表结构,原表数据被删除

3、导入 .idb文件现有数据库

也就是添加表数据,不过,目前还没有绑定

alter table `表1`  import   tablespace;
alter table `表2`  import   tablespace;
......

mysql数据恢复方法个人总结

mysql具有binlog功能,可以记录对表进行过的操作、执行过的sql语句;

以下主要是总结下binlog的开启方法、使用方法等;

如果误删数据库表中的某些数据、或者误删整个表、误修改表结构等,就可以使用这个方法进行恢复。

步骤

1.如果想使用MySql数据恢复功能,首先需要修改Mysql配置文件,开启binlog功能。(有些版本binlog默认是不开启的,因此需要手动修改配置文件开启)

(1)windows环境

配置文件名称为my.ini,可以安装软件everything搜索这个文件。路径样例如下:

C:ProgramDataMySQLMySQL Server 5.7my.ini

(2)linux环境

配置文件名称为my.cnf,可以使用find命令搜索文件所在位置:

sudo find / -name my.cnf

位置样例如下:

/etc/my.cnf

2.找到配置文件后(my.ini/my.cnf),新增以下配置即可(当然先看看配置文件是否已配置了这行,不要重复了):

log-bin=mysqlbinlog
binlog-format=ROW

或者也可以指定binlog的位置(下方是linux下的路径):

log-bin=/data/mysql/log/mysqlbinlog
binlog-format=ROW

注意,指定binlog在某个文件夹下时,必须自己创建文件夹,否则重启mysql会报错。

3.配置完成后,重启mysql。

4.现在,对mysql的数据库、表、数据等操作、执行增删改sql,都会记录到binlog中。(搜索mysqlbinlog就可以找到这个日志文件)

5.进行测试,新建一个表binlog_test,列随意,然后写几行数据,然后清空表数据。(准备使用binlog还原数据)

6.查看binlog的命令如下:

mysql> show binlog events;   #只查看第一个binlog文件的内容
mysql> show binlog events in 'mysqlbinlog.000002';#查看指定binlog文件的内容
mysql> show binary logs;  #获取binlog文件列表
mysql> show master status; #查看当前正在写入的binlog文件

7.首先看当前使用的是哪个binlog:

show master status;

本人执行后,发现当前使用的binlog是:mysqlbinlog.000004

8.然后查看这个binlog的内容:

show binlog events in 'mysqlbinlog.000004';

执行后,可以从查询结果的Info列中,找到刚才创建binlog_test表的sql(对应的Event_type是Query);

可以看到刚才清空表数据的记录行,Event_type是Delete_rows;

在上一些,可以看到创建表后、新增数据的Event_type是Write_rows;

9.分析这个binlog,我们的目标是还原刚才被删除的数据,因此找到create table语句后的第一个Event_type是Query的行,它的Pos为460;

再找到Event_type是Delete_rows上面最接近的、Info中是COMMIT的行,它的Event_type是Xid,End_log_pos是1199。

(每一行的End_log_pos对应下一行的Pos)

10.现在找到了一个范围,从460到1199之间的执行日志,就是给表binlog_test增加数据的日志,因此只要重复执行这之间的操作,就可以还原数据了。

11-1.windows下,找到mysqlbinlog.exe的位置;

linux下,找到mysqlbinlog的位置(这个是mysql的bin目录下的一个可执行文件);

然后执行以下命令,即可还原数据:

mysqlbinlog --no-defaults --start-position=460 --stop-position=1199 "C:ProgramDataMySQLMySQL Sever 5.7Datamysqlbinlog.000004" -d test | mysql -uroot -proot test

其中,指定了开始位置为460,结束位置为1199,命令执行后就会读取日志中指定范围内的命令并重新执行。

其它命令的含义为:

  • "-d test"的意思是,指定数据库为test(binlog_test表在test数据库中)
  • "|"是管道符
  • "mysql -uroot -proot test"是mysql的账号密码、登陆目标数据库
  • "-uroot":账号是root
  • "-proot":密码是root
  • "test":数据库是test

11-2.也可以把binlog日志中,指定范围内的日志导出,然后自己执行source命令还原数据,如下:

mysqlbinlog "C:ProgramDataMySQLMySQL Sever 5.7Datamysqlbinlog.000004" -d test  --skip-gtids  --start-position=460 --stop-position=1199 > test.sql

执行这个命令后,指定范围内的日志被导出到test.sql中;

然后登陆mysql,执行命令:

mysql> use test; 
mysql> source test.sql;

这样就可以还原数据了。

其它笔记

1.如果使用truncate删除表的数据,binlog中也会新增几行记录,记录truncate操作,样例如下:

mysqlbinlog.000004 | 3122 | Query | 1 | 3211 | use 'test'; TRUNCATE 'binlog_test'

如果想恢复数据,就需要找到最开始插入数据的Pos、到truncate之前的End_log_pos,然后重新执行这期间的命令。

2.增删改操作会记录到binlog中,慢查询sql也可以记录到慢查询log中,不过也需要自己修改配置文件开启慢查询日志。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • mysql 直接拷贝data 目录下文件还原数据的实现

    mysql 拷贝data 目录下的文件还原数据 背景:MySQL的的崩溃无法启动,决定重新搭环境,但数据库测试数据忘记备份时,MySQL的的数据目录幸存 操作: 1,复制测试数据库的文件夹(包含.frm .ibd等文件) 2,重启mysql 通过Navicat查看数据库某张表,结果显示"表'xxx 不存在 " 3,各种谷歌,百度后发现innodb的表 直接复制文件是无法使用的,会提示表不存在,在复制的时候,应将数据目录下的ibdata1文件一并复制过去,并且删除ib_logfile0,

  • mysql 5.7.21 解压版通过历史data目录恢复数据的教程图解

    情况说明: 数据库非正常启动关闭导致再次启动服务的时候,提示一直"正在启动",无奈只好重新安装该解压版程序. 关于如何安装:https://www.jb51.net/article/148140.htm 请访问该文章. 安装成功并生成data文件目录,设置好用户密码之类的,目录效果如下: 下面进行数据恢复,很简单. 1.找到之前(我之前一直启动不成功路径F:\mysql-5.7.21-winx64)的数据库目录下的data文件夹,目录如下: 里面有很多的历史文件,其他都不要管,1 是i

  • 详解Mysql自动备份与恢复的几种方法(图文教程)

    自动备份MySQL 5.0有三个方案:  备份方案一: 通过 mysqldump命令,直接生成一个完整的 .sql 文件 Step 1: 创建一个批处理 (说明:root 是mysql默认用户名, aaaaaa 是mysql密码, bugtracker 是数据库名) ------------mySql_backup.bat-------------------------------------------------------------------------------------- d

  • mysql数据如何通过data文件恢复

    目录 mysql数据通过data文件恢复 mysql数据恢复方法个人总结 步骤 其它笔记 总结 mysql数据通过data文件恢复 mysql磁盘文件被损坏,无法启动,能看到data文件,在没有备份的话如何复原? 情景1:知道数据库中的表结构 1.先执行表结构语句 2.解除绑定 alter table `表1`  discard  tablespace; alter table `表2`  discard  tablespace; ...... 此时当前数据库下所有的.idb文件都会被删除,也就

  • Python实现mysql数据库中的SQL文件生成和导入

    目录 1.将mysql数据导出到SQL文件中(数据库存在的情况) 2.将现有的sql文件数据导入到数据库中(前提数据库存在) 3.利用Navicat导出SQL文件和导入SQL文件 1)从数据库导出SQL文件 2)导入SQL文件到数据库 1.将mysql数据导出到SQL文件中(数据库存在的情况) 主要需要修改数据库的相关信息,端口号.用户名.密码等 其中数据库得存在,不然会报错 : #!/usr/bin/env python # -*- coding: utf-8 -*- # @descripti

  • MySQL 利用frm文件和ibd文件恢复表数据

    frm文件和ibd文件简介 在MySQL中,如果我们使用了默认的存储引擎innodb创建一张表,那么在文件夹下面就会出现表名.frm和表名.ibd两个文件,如果我们使用的是Myisam存储引擎,那么就会出现三个文件,这里我们给出例子: [root@ /data/yeyz]#ll total 580 -rw-rw---- 1 mysql mysql 8586 Apr 3 17:44 a.frm -rw-rw---- 1 mysql mysql 0 Apr 3 17:44 a.MYD -rw-rw-

  • 教你如何通过日志文件恢复MySQL数据

    目录 前言 1.找到最新的 binlog 文件 2.找到我们想恢复数据在日志文件里的开始结束位置 2.1.使用时间范围 2.2.使用 position 范围 3.恢复 3.1 通过时间恢复 3.2 通过 position 恢复 总结 前言 本文将讲述怎么通过 MySql 的日志 binlog 文件进行数据恢复. 通过已备份数据 加上 binlog 文件恢复上次备份到删除之间的数据 1.找到最新的 binlog 文件 进入 mysql 命令行执行如下命令 mysql> show master st

  • Mysql通过ibd文件恢复数据的详细步骤

    恢复步骤 1.创建数据库(随意创建) 2.创建数据表(备注:表结构要和要恢复的表结构一致,row_format要和ibd文件的row_format一致,否则,会提示两者不一致. 当前row_format=dynamic) 3.表的属性查看 我们使用:show table status like ‘matlab’\G,查看表的属性 备注:创建表时候的row_format和表属性的不一致,基于innodb是,要把row_format设置成dynamic时,需要修改mysql的全局配置,直接在myql

  • mysql二进制日志文件恢复数据库

    二进制日志的文件的作用 mysql二进制日志文件用来记录所有用户对数据库操作,即记录用户对数据库操作的sql语句.如果有此文件,当数据库发生意外时,可以通过此文件查看到用户在此文件记录的时间段内用户所做的操作,再和数据库备份配合使用,即可再现用户操作,使数据库恢复. 二进制日志文件的弊端 二进制日志文件开启后,所有对数据库操作的记录均会被记录到此文件, 所以,当长时间开启之后,日志文件会变得很大,占用磁盘空间. 使用二进制日志文件恢复数据库 开启日志文件 mysql默认是不开启日志文件的功能的,

  • Windows下修改mysql的data文件夹存放位置的方法

    按照正常步骤进行mysql的安装之后,发现datadir的默认目录是 复制代码 代码如下: C:\Documents and Settings\All Users\Application Data\MySQL\MySQL Server 5.1\data 本来C盘容量就不多,当然不能放在这个里面~~所以按照网上的步骤,在my.ini文件中进行了修改,然后在"服务"里面重启服务,可怕的事情发生了,出现了"本地计算机无法启动Mysql服务"的错误,愁苦死了,只好卸载又重装

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

     一.binlog 介绍 服务器的二进制日志记录着该数据库的所有增删改的操作日志(前提是要在自己的服务器上开启binlog),还包括了这些操作的执行时间.为了显示这些二进制内容,我们可以使用mysqlbinlog命令来查看. 用途1:主从同步 用途2:恢复数据库(也是线上出现一次数据库文件丢失后,才对这个有所了解并学习的) mysqlbinlog命令用法:shell> mysqlbinlog [options] log_file ... <!--[if !supportLists]-->

  • Linux下实现MySQL数据备份和恢复的命令使用全攻略

    为了保障数据的安全,需要定期对数据进行备份.备份的方式有很多种,效果也不一样.一旦数据库中的数据出现了错误,就需要使用备份好的数据进行还原恢复.从而将损失降到最低.下面我们来了解一下MySQL常见的有三种备份恢复方式: 1.利用Mysqldump+二进制日志实现备份 2.利用LVM快照+二进制日志实现备份 3.使用Xtrabackup备份 一:实验环境介绍: 系统介绍:CentOS6.4_X64 数据库版本:mysql-5.5.33 二:基于Mysqldump命令实现备份恢复 2.1.思路概念

随机推荐