mysql备份恢复

mysqldump备份

企业故障恢复案例:
正在运行的网站系统 mysql数据库 数据量25G,日业务量10-15M
备份策略:
每天晚上23点通过计划任务调用mysqldump执行全备脚本 故障时间点:
周四上午 开发误删除了一个表,如何恢复? 思路:
1. 停业务避免数据二次伤害
2. 找一个临时库,恢复周三23.00 全备
3. 截取 周三 23.00 ---> 周四10点 误删除之间的binlog,恢复到临时数据库
4. 测试可用性和完整性
5.
5.1 方法1: 直接用临时卡顶替原有生产库,前端应用割接到新库
5.2 方法2: 将误删除的表导出,导入到原生产库
6. 开启业务

故障演练:

mysql> show master status;
+------------------+----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000007 | 2070 | | | |
+------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec) mysql> flush logs;
Query OK, 0 rows affected (0.01 sec) #创建一个新库
mysql> create table backup.full select * from world.city;
Query OK, 4079 rows affected (0.04 sec)
Records: 4079 Duplicates: 0 Warnings: 0 #这个直接取了 实验文件 wolrd 的数据到新库。 现在有数据了。 mysql> create table backup.full_1 select * from mysql.user;
Query OK, 4 rows affected (0.01 sec)
Records: 4 Duplicates: 0 Warnings: 0 验证数据是否有了:
mysql> use backup
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A Database changed
mysql> show tables;
+------------------+
| Tables_in_backup |
+------------------+
| full |
| full_1 |
+------------------+
2 rows in set (0.00 sec) #可以看到有两个数据表了。 现在做一次全备。 ## 周三全备:
[root@localhost ~]# mkdir /backup -p
[root@localhost ~]# cd /backup
[root@localhost ~]# mysqldump -uroot -p123 -A -R --triggers --master-data=2 --single-transaction|gzip >/backup/full_$(date +%F).sql.gz
[root@localhost ~]# ll -h /backup/
total 328K
-rw-r--r-- 1 root root 328K Oct 12 21:25 full_2020-10-12.sql.gz ## 模拟23:00到周四数据丢失的变化【属于正常修改】
现在在创建一点数据
mysql> create table backup.thur select * from world.country;
Query OK, 239 rows affected (0.01 sec)
Records: 239 Duplicates: 0 Warnings: 0 通过查询可以看到:
select * from backup.full;
4079 rows in set (0.01 sec) 有439行数据。 模拟删除修改数据:
mysql> use backup;
mysql> update full set countrycode='CHN'; #模拟不小心把所有地区都改为了CHN
mysql> commit;
Query OK, 0 rows affected (0.00 sec) #并执行了提交 mysql> delete from full where id>200; #大部分数据都删除了 只保留了200行
Query OK, 3879 rows affected (0.02 sec) mysql> commit; #并执行了提交
Query OK, 0 rows affected (0.00 sec) ### 模拟故障,删除了一个表 【属于异常修改】
mysql> show tables;
+------------------+
| Tables_in_backup |
+------------------+
| full |
| full_1 |
| thur |
+------------------+
3 rows in set (0.00 sec) mysql> drop table thur; #<------------ 删除表
Query OK, 0 rows affected (0.00 sec) mysql> show tables; #现有表
+------------------+
| Tables_in_backup |
+------------------+
| full |
| full_1 |
+------------------+
2 rows in set (0.00 sec) ----------------------------------------------- ----------------------------------------------- 恢复过程:
1. 关闭原有数据库 2. 启动一个新数据库 3. 解压备份数据
[root@localhost backup]# gzip -d full_2020-10-12.sql.gz
[root@localhost backup]# ll
total 1104
-rw-r--r-- 1 root root 1126759 Oct 12 21:25 full_2020-10-12.sql 4. 截取二进制日志:
去备份的sql中找
[root@localhost backup]# vim full_2020-10-12.sql
在这里明显可以看到备份的那个binlog日志和起始位置:
-- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000008', MASTER_LOG_POS=120; #备份文件中的起始位置 mysqlbinlog --start-position=120 --stop-position=[待查找] /data/mysql/mysql-bin.000008 5. 获取binlog日志最后一次正常操作的binlog。
mysql> show master status;
+------------------+----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000008 | 399383 | | | |
+------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec) 找出删除时间点的 position号:
| mysql-bin.000008 | 399262 | Query | 1 | 399383 | use `backup`; DROP TABLE ...
找到开始位置 399262 [这是删除这个表之前的位置。] 将命令的结尾改成下面这样,然后执行:
[root@localhost backup]# mysqlbinlog --start-position=120 --stop-position=399262 /data/mysql/mysql-bin.000008 >/backup/inc.sql 6. 截取数据完毕后,开始恢复数据:
先去一台临时mysql服务器恢复数据,检查
root@localhost backup]# scp -r /backup/inc.sql root@10.0.0.61:/root 另一台数据库操作如下:
set sql_log_bin=0;
source /root/full_2020-10-12.sql
source /root/inc.sql 检查数据:
MariaDB [world]> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| backup |
| binlog |
| mysql |
| performance_schema |
| test |
| world |
+--------------------+
7 rows in set (0.00 sec) MariaDB [backup]> show tables; #船舰的表都在
+------------------+
| Tables_in_backup |
+------------------+
| full |
| full_1 |
| thur |
+------------------+
3 rows in set (0.00 sec) 恢复完毕。

mysql binlog故障演练的更多相关文章

  1. Slave_SQL_Running: No mysql同步故障解决方法

    Slave_SQL_Running: No mysql同步故障解决      今天检查数据库发现一台MySQL Slave未和主机同步,查看Slave状态:mysql> show slave s ...

  2. keepalive配置mysql自动故障转移

    keepalive配置mysql自动故障转移 原创 2016年02月29日 02:16:52 2640 本文先配置了一个双master环境,互为主从,然后通过Keepalive配置了一个虚拟IP,客户 ...

  3. MySQL Binlog 介绍

    Binlog 简介 MySQL中一般有以下几种日志: 日志类型 写入日志的信息 错误日志 记录在启动,运行或停止mysqld时遇到的问题 通用查询日志 记录建立的客户端连接和执行的语句 二进制日志 记 ...

  4. MySql Binlog 说明 & Canal 集成MySql的更新异常说明 & MySql Binlog 常用命令汇总

    文章来源于本人的印象笔记,如出现格式问题可访问该链接查看原文 原创声明:作者:Arnold.zhao 博客园地址:https://www.cnblogs.com/zh94 目录 背景介绍 开启MySq ...

  5. MySQL binlog中的事件类型

    MySQL binlog记录的所有操作实际上都有对应的事件类型的,譬如STATEMENT格式中的DML操作对应的是QUERY_EVENT类型,ROW格式下的DML操作对应的是ROWS_EVENT类型. ...

  6. MySQL Binlog Mixed模式记录成Row格式

    背景: 一个简单的主从结构,主的binlog format是Mixed模式,在执行一条简单的导入语句时,通过mysqlbinlog导出发现记录的Binlog全部变成了Row的格式(明明设置的是Mixe ...

  7. MySQL binlog的格式解析

    我搜集到了一些资料,对理解代码比较有帮助. 在头文件中binlog_event.h中,有描述 class Log_event_header class Log_event_footer 参见[Myst ...

  8. Mysql binlog

    理解Mysql binlog 日志的三种模式   本文介绍下,mysql中binlog日志的三种模式,了解了各种模式的不同之处,才能更好地应用.有需要的朋友建议参考下.   一,模式1 Row Lev ...

  9. [转]mysql binlog in realtime

    原文:http://guweigang.com/blog/2013/11/18/mysql-binlog-in-realtime/ 众所周知,MySQL是最受欢迎的互联网数据库(没有之一)—————— ...

  10. MySQL bin-log 日志清理方式

    MySQL bin-log 作用   1.数据恢复:如果你的数据库出问题了,而你之前有过备份,那么可以看日志文件,找出是哪个命令导致你的数据库出问题了,想办法挽回损失. 2.主从服务器之间同步数据:主 ...

随机推荐

  1. 重新点亮linux 命令树————su和sudo[七]

    前言 简单整理一下su和sudo这两个命令. 正文 su 这个命令是用来切换用户的. 一般我们切换命令su,还是在原来的路径下面,但是如果想要直接回到切换用户的用户目录的话,可以使用su - user ...

  2. 站点js屏蔽他人广告

    前言 以前自己建设博客的时候,出现一个问题,那就是动不动弹出广告,不晓得这个是怎么查到我的站点的,但是加入了屏蔽js,就没遇到了,在此分享. 正文 防止动态加载script脚本 (function ( ...

  3. springboot+thymeleaf+mybatis实现甘特图(代码非常详细)

    首先我们要明白:这个甘特图需要哪些动态数据. (1)需要:ID,tName,number,计划开始时间,开始时间,计划结束时间,结束时间,项目负责人,参与人,知情人ID,计划时长(可以计算得出的,不必 ...

  4. CentOS7.9 systemctl

    目录 命令格式 语法 加载配置文件 关机和开机 unit 文件存放位置 unit 格式说明 service unit file 文件构成部分 unit 段的常用选项 service 段的常用选项 in ...

  5. gRPC入门学习之旅(七)

    gRPC入门学习之旅(一) gRPC入门学习之旅(二) gRPC入门学习之旅(三) gRPC入门学习之旅(四) gRPC入门学习之旅(五) gRPC入门学习之旅(六) 3.6.创建gRPC的桌面应用客 ...

  6. 痞子衡嵌入式:在i.MXRT1xxx系列上用NAND型启动设备时可用两级设计缩短启动时间

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是在i.MXRT1xxx系列上用NAND型启动设备时可用两级设计缩短启动时间. 去年痞子衡写过一篇骚操作文章 <借助i.MXRT10 ...

  7. MySQL正则表达式:REGEXP 和 LIKE

    正则表达式作用: 根据指定的匹配模式匹配文中符合要求的特殊字符. REGEXP : ①操作符中常用的匹配列表: ②匹配特殊字符使用\\进行转义 \\.   能够匹配 . \\f   换页 \\n 换行 ...

  8. [K8s] Docker 单节点部署 Rancher

    Rancher 是通过 Web 界面管理 k8s 集群的工具,本身支持使用 Docker 启动. 单节点部署只需要 docker run 即可,易用性高,高可用部署可以使用 nginx 反向代理机制. ...

  9. 记 dotnet 8.0.4 修复的 WPF 的触摸模块安全问题

    本文记录 dotnet 8.0.4 版本修复的 WPF 的触摸模块安全问题,此问题影响所有的 .NET 版本,修复方法是更新 SDK 和运行时 宣布安全漏洞地址: https://github.com ...

  10. 2019-10-31-win10-uwp-录制任意应用屏幕

    title author date CreateTime categories win10 uwp 录制任意应用屏幕 lindexi 2019-10-31 09:10:38 +0800 2019-10 ...