mysql数据安全一之数据恢复案例

--chenjianwen

应用场景:适宜开启binlog 日志功能,定时备份并使用--master-data参数备份,在某个时间点丢失数据,用于数据恢复

开篇总结:

(1)本案例适用于人为SQL语句造成的误操作或者没有主从复制等的热备情况宕机时的修复

(2)恢复条件为mysql要开启binlog日志功能,并且要全备和增量的所有数据

(3)恢复时建议对外停止更新,即禁止更新数据库

(4)先恢复全量,然后把全备时刻点以后的增量日志,按顺序恢复成SQL文件,然后把文件中有问题的SQL语句删除(也可通过时间和位置点),再恢复到数据库。

1.确保 MySQL 开启了 binlog 日志功能,并做好备份计划任务

2.mysql备份语句:mysqldump -uroot -pxxx -B -F -R -x --master-data=2 chenjianwen01|gzip >./chenjianwen01_$(date +%F).sql.gz

参数说明:
-B:指定数据库
-F:刷新日志
-R:备份存储过程等
-x:锁表
–master-data:在备份语句里添加CHANGE MASTER语句以及binlog文件及位置点信息

3.解压保留源文件命令:gunzip -c chenjianwen01_2017-08-30.sql.gz > chenjianwen01_2017-08-30.sql

4.查看表中的数据:

mysql> select * from userinfo;
+----------+---------------+-----------+
| fuser_id | fuser_name | fuser_age |
+----------+---------------+-----------+
| 2 | chenjianwen02 | 22 |
| 3 | 陈建文 | 22 |
+----------+---------------+-----------+
2 rows in set (0.00 sec)

5.再次向数据表中插入数据:

mysql> show tables;
+-------------------------+
| Tables_in_chenjianwen01 |
+-------------------------+
| classinfo |
| userinfo |
+-------------------------+
2 rows in set (0.00 sec) mysql> desc userinfo;
+------------+-------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+------------+-------------+------+-----+---------+----------------+
| fuser_id | int(11) | NO | PRI | NULL | auto_increment |
| fuser_name | varchar(64) | NO | | NULL | |
| fuser_age | int(11) | NO | | NULL | |
+------------+-------------+------+-----+---------+----------------+
3 rows in set (0.00 sec) mysql> insert into userinfo (fuser_name,fuser_age) values ("chenjianwen03",22);
Query OK, 1 row affected (0.00 sec) mysql> insert into userinfo (fuser_name,fuser_age) values ("chenjianwen04",23);
Query OK, 1 row affected (0.00 sec) mysql> insert into userinfo (fuser_name,fuser_age) values ("chenjianwen05",21);
Query OK, 1 row affected (0.00 sec) mysql> select * from userinfo;
+----------+---------------+-----------+
| fuser_id | fuser_name | fuser_age |
+----------+---------------+-----------+
| 2 | chenjianwen02 | 22 |
| 3 | 陈建文 | 22 |
| 4 | chenjianwen03 | 22 |
| 5 | chenjianwen04 | 23 |
| 6 | chenjianwen05 | 21 |
+----------+---------------+-----------+
5 rows in set (0.00 sec)

6.此时误操作,删除了数据库

mysql> drop database chenjianwen01;
Query OK, 2 rows affected (0.02 sec)

此时,全备之后到误操作时刻之间,用户写入的数据在 binlog 中,需要恢复出来!

7.查看备份之后新增的 binlog 文件

[root@cjw_jdy backup]# cd /root/backup/
[root@cjw_jdy backup]# gunzip -c chenjianwen01_2017--.sql.gz > chenjianwen01_2017--.sql
[root@cjw_jdy backup]# grep CHANGE chenjianwen01_2017--.sql
-- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000022', MASTER_LOG_POS=;

这是备份时刻的 binlog 文件位置,即 mysql-bin.000022 的 120 行,因此在该文件之前的 binlog 文件中的数据都已经包含在这个备份的 SQL 文件中了。

8.拷贝binlog 文件,并将mysql-bin.000022导出为sql文件,并删除里面的drop语句

[root@cjw_jdy backup]# cp /home/mysql/data/mysql-bin. .
[root@cjw_jdy backup]# ls
chenjianwen01_2017--.sql chenjianwen01_2017--.sql.gz mysql-bin.
[root@cjw_jdy backup]# mysqlbinlog -d chenjianwen01 mysql-bin. > mysql-bin..sql
[root@cjw_jdy backup]# ls
chenjianwen01_2017--.sql chenjianwen01_2017--.sql.gz mysql-bin. mysql-bin..sql
[root@cjw_jdy backup]# cat mysql-bin..sql | grep -i drop
[root@cjw_jdy backup]# rm -rf /home/mysql/data/mysql-bin.000022

注意:在恢复全备数据之前必须将该binlog文件移出,否则恢复过程中,会继续写入语句到binlog,最终导致增量恢复数据部分变得比较混乱。

9.恢复数据,导入前需要先创建数据库,查看表信息,没有备份后插入的数据

mysql> create database chenjianwen01 charset utf8;
Query OK, row affected (0.00 sec) [root@cjw_jdy backup]# mysql -uroot -p chenjianwen01 < chenjianwen01_2017--.sql mysql> select * from userinfo;
+----------+---------------+-----------+
| fuser_id | fuser_name | fuser_age |
+----------+---------------+-----------+
| | chenjianwen02 | |
| | 陈建文 | |
+----------+---------------+-----------+
rows in set (0.00 sec)

10.使用mysql-bin.000022.sql文件恢复备份时刻到删除数据库之间新增的数据

[root@cjw_jdy backup]# mysql -uroot -p chenjianwen01 < mysql-bin..sql

11.检查恢复后的数据

mysql> select * from userinfo;
+----------+---------------+-----------+
| fuser_id | fuser_name | fuser_age |
+----------+---------------+-----------+
| | chenjianwen02 | |
| | 陈建文 | |
| | chenjianwen03 | |
| | chenjianwen04 | |
| | chenjianwen05 | |
+----------+---------------+-----------+
rows in set (0.00 sec)

mysql数据库增量数据恢复的实例过程【Good job】

mysql数据安全一之数据恢复案例的更多相关文章

  1. MySQL 之数据库增量数据恢复案例

    MySQL 数据库增量数据恢复案例 一.场景概述 MySQL数据库每日零点自动全备 某天上午10点,小明莫名其妙地drop了一个数据库 我们需要通过全备的数据文件,以及增量的binlog文件进行数据恢 ...

  2. MySQL 数据库增量数据恢复案例

    MySQL 数据库增量数据恢复案例 一.场景概述 MySQL数据库每日零点自动全备 某天上午10点,小明莫名其妙地drop了一个数据库 我们需要通过全备的数据文件,以及增量的binlog文件进行数据恢 ...

  3. MySQL中truncate误操作后的数据恢复案例

    MySQL中truncate误操作后的数据恢复案例 这篇文章主要介绍了MySQL中truncate误操作后的数据恢复案例,主要是要从日志中定位到truncate操作的地方然后备份之前丢失的数据,需要的 ...

  4. mysql数据安全之利用二进制日志mysqlbinlog备份数据

    mysql数据安全之利用二进制日志mysqlbinlog备份数据 简介:如何利用二进制日志来备份数据 什么是二进制日志: 二进制日志就是记录着mysql数据库中的一些写入性操作,比如一些增删改,但是, ...

  5. 阿里云ECS(linux)磁盘满触发的mysql的表异常修复案例

    阿里云ECS(linux)磁盘满触发的mysql的表异常修复案例 阿里云技术支持:完颜镇江 问题现象: 磁盘空间满了,第一想到的就是删除无用的服务日志或者升级数据盘. 通常是使用du –sh去分析目录 ...

  6. mysql 启动失败,数据恢复

    mysql 启动失败,数据恢复 2017年02月13日 16:46:36 阅读数:621 Forcing InnoDB Recovery提供了6个等级的修复模式,需要注意的是值大于3的时候,会对数据文 ...

  7. mysql的binlog进行数据恢复

    什么是binlog? binlog,也称为二进制日志,记录对数据发生或潜在发生更改的SQL语句,并以二进制的形式保存在磁盘中,可以用来查看数据库的变更历史(具体的时间点所有的SQL操作).数据库增量备 ...

  8. mysql利用binlog进行数据恢复

    目录 mysql利用binlog进行数据恢复 binlog基本配置和格式 binlog基本配置 查看binlog状态 binlog的三种格式 转换成sql mysql自带的mysqlbinlog 利用 ...

  9. MySQL 误操作后数据恢复(update,delete忘加where条件)【转】

    在数据库日常维护中,开发人员是最让人头痛的,很多时候都会由于SQL语句 写的有问题导致服务器出问题,导致资源耗尽.最危险的操作就是在做DML操作的时候忘加where条件,导致全表更新,这是作为运维或者 ...

随机推荐

  1. 熟悉linux命令

    <鸟哥的linux私房菜>这本书终于看到了敲命令行这块了,有点小激动,打开虚拟机,开始~~~敲!!! 登录界面,用户名密码~~~ 登录成功,下面开始熟悉一下,linux的常见命令了: li ...

  2. 《gradle 用户指南中文版》第3章 安装 gradle

    macOS 下安装 gradle,只要可以安装sdk的系统,使用sdk来安装,那么安装方式基本是一样的. Gradle在所有主要操作系统上运行,只需要安装Java JDK或JRE版本7或更高版本.要检 ...

  3. flowable ContentEngine和ContentEngineConfiguration的关系

    一.CommandExecutor ContentEngineConfiguration继承自 AbstractEngineConfiguration. 在 AbstractEngineConfigu ...

  4. Android Studio com.android.dex.DexException: Multiple dex files define(重复引用包),androiddefine

    Android Studio com.android.dex.DexException: Multiple dex files define(重复引用包),androiddefine 如果你用Andr ...

  5. CS231n课程笔记翻译3:线性分类笔记

    译者注:本文智能单元首发,译自斯坦福CS231n课程笔记Linear Classification Note,课程教师Andrej Karpathy授权翻译.本篇教程由杜客翻译完成,巩子嘉和堃堃进行校 ...

  6. Objective C - 2 - 随机数,可变字符串,字符串,SubString

    int main(int argc, const char * argv[]) { @autoreleasepool { NSString *outputString = @"1234567 ...

  7. iOS怎么来实现关闭自动锁屏

    怎么来设置[UIApplication sharedApplication]   idleTimerDisabled 属性来控制自动锁屏的效果 // 把设置idleTimerDisabled的代码放到 ...

  8. js之10天内免登陆

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. Python源码分析(一)

    最近想学习下Python的源码,希望写个系列博客,记录的同时督促自己学习. Python源码目录 从Python.org中下载源代码压缩包并解压,我下载的是Python2.7.12,解压后: 对于主要 ...

  10. 3DsMax动画插件

    * 简易骨骼动画: Mesh当前帧顶点 = Mesh绑定时顶点 * 绑定时骨骼的变换到本帧骨骼的变换的改变量. = Mesh绑定时顶点 * 绑定时骨骼的变换的逆矩阵 * 本帧的骨骼变换. = Mesh ...