场景描述

*********************************************

在远程服务器做的全备并已经恢复,同时使用binlog server备份binlog

之后,删除了库中所有表,然后又重建一批表,并插入了大量数据,重建的表与原来的表有重名的表(比如sbtest1)

然后要求恢复删除之前其中一张表sbtest1的数据

恢复思路

************************************************

由于在远程服务器上做了全备,并已经进行了全备的恢复,那么就可以按以下思路进行

1. 从远程服务器备份的binlog中找到删除操作的事务位置之前的一个位置pos

2. 在远程服务器上创建一个只有对表sbtest1有所有权限的用户,用于只恢复sbtest1,从而跳过其他事务;此步非必需。

3. 找到全备的起点,也是恢复的起点(在备份时加master-data参数后,备份文件初始-- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000012', MASTER_LOG_POS=190;)

恢复准备

**********************************************

全备起点
-- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000016', MASTER_LOG_POS=190;

原库设置数据
update sbtest3 set pad='扫此二微码,免费领取小礼品' where id=101;
update sbtest2 set pad='扫此二微码,免费领取小礼品' where id=101;
update sbtest1 set pad='扫此二微码,免费领取小礼品' where id=101;

误操作
update sbtest3 set pad='此活动已结束' where id=101;
drop table sbtest3;

确认误操作具体位置

mysqlbinlog --no-defaults --database=txdb -v -v --base64-output=decode-rows --skip-gtids --start-datetime="2018-07-31 16:10:00" --stop-datetime="2018-07-31 16:20:00" mysql-bin.000016> /tmp/3.sql

split -l 100000 3.sql s_

BEGIN
/*!*/;
# at
# :: server id end_log_pos Rows_query
# update sbtest3 set pad='扫此二微码,免费领取小礼品' where id=
# at
# :: server id end_log_pos Table_map: `txdb`.`sbtest3` mapped to number
# at
# :: server id end_log_pos Update_rows: table id flags: STMT_END_F
### UPDATE `txdb`.`sbtest3`
### WHERE
### @= /* INT meta=0 nullable=0 is_null=0 */
### @= /* INT meta=0 nullable=0 is_null=0 */
### @='99505216625-44652318903-87633088031-12891470052-20814553735-53032754476-32543784485-39935334177-82742270613-55767522233' /* STRING(360) meta=61032 nullable=0 is_null=0 */
### @='46607138393-89004745809-36733255854-15721737050-37472852755' /* STRING(180) meta=65204 nullable=0 is_null=0 */
### SET
### @= /* INT meta=0 nullable=0 is_null=0 */
### @= /* INT meta=0 nullable=0 is_null=0 */
### @='99505216625-44652318903-87633088031-12891470052-20814553735-53032754476-32543784485-39935334177-82742270613-55767522233' /* STRING(360) meta=61032 nullable=0 is_null=0 */
### @='扫此二微码,免费领取小礼品' /* STRING(180) meta=65204 nullable=0 is_null=0 */
# at
# :: server id end_log_pos Xid =
COMMIT/*!*/;
# at
# at
# :: server id end_log_pos Query thread_id= exec_time= error_code=
SET TIMESTAMP=/*!*/;

以上方法在mysql备份与恢复是通用的,一个全备,binlog,恢复的起点与终点。恢复的方法有好几种,下面举例说明几个。

最常用的恢复

**************************************************************

适用于小数据量,即全备的时刻距离故障的时刻产生的binlog量不多,基本上所需要恢复的数据在一个binlog文件中

mysqlbinlog --no-defaults --database=txdb --skip-gtids --start-position=190 --stop-position=888 mysql-bin.000016 > /tmp/rec.sql

注意:stop-position是commit标志前后的这个pos,它们是一样的,在本例中是 end_log_pos 888 与 at 888,它是一个事务的结束点,也是另外一个事务的开始点

确认一下/tmp/rec.sql文件的结尾,是否有删除的操作,确保不会再重复删除

mysql -uautomng -pAutomng_123 -P3319 --database=txdb < /tmp/rec.sql

然后确认数据库,数据已经到预期的时间点上了

mysql> select pad from sbtest3 where id=101;
+-----------------------------------------+
| pad |
+-----------------------------------------+
| 扫此二微码,免费领取小礼品 |
+-----------------------------------------+
1 row in set (0.01 sec)

从恢复机导出该表,然后再导入到误操作的库中

mysqldump -uautomng -pAutomng_123 -P3319 --databases txdb --tables sbtest3 > /tmp/sbtest3.sql

scp /tmp/sbtest3.sql mysql01:/tmp

/tmp/sbtest3.sql中默认已经带上删除表的语句了

DROP TABLE IF EXISTS `sbtest3`;

mysql -uautomng -pAutomng_123 -S /data0/mysql/log/bak/mysql_bak.sock txdb< /tmp/sbtest3.sql

确认误操作数据库是否恢复

mysql> select pad from sbtest3 where id=101;
+-----------------------------------------+
| pad |
+-----------------------------------------+
| 扫此二微码,免费领取小礼品 |
+-----------------------------------------+
1 row in set (0.00 sec)

回顾总结

此例版本mysql5.7.22

不自己操作一遍,永远不知道这里面有多少坑!其他方法后续会补充。

my09_mysql指定时间点恢复之binlog start-position的更多相关文章

  1. 挖一挖MongoDB的备份与还原(实现指定时间点还原和增量备份还原)

    一  研究背景需求 目前作者所在公司的MongoDB数据库是每天凌晨做一次全库完整备份,但数据库出现故障时,只能保证恢复到全备时间点,比如,00:30 做的完整备份,而出现故障是下午18:00,那么现 ...

  2. 【转】Expire Google Drive Files 让Google Docs云盘共享连接在指定时间后自动失效

    最近在清理Google Docs中之前共享过的文件链接,发现Google Docs多人协作共享过的链接会一直存在,在实际操作中较不灵活.正好订阅的RSS推送了Pseric写的这篇文章 - Expire ...

  3. 在指定时间干,必须干(kbmmw 中的事件调度)

    从去年开始,kbmmw 慢慢增加内涵,除了完善各种服务外,陆续增加和扩展了作为一个中间件必须有的功能, 例如,权限管理.日志系统.调度系统.内存调试等功能. 今天给大家介绍一下kbmmw 的调度事件, ...

  4. SQL Server 获取最后一天(指定时间的月最后一天日期)

    /* author OceanHo @ 2015-10-23 10:14:21 获取指定时间字符串指定日期的月最后一天日期 */ IF OBJECT_ID('get_LastDayDate') IS ...

  5. C#使用Timer.Interval指定时间间隔与指定时间执行事件

    C#中,Timer是一个定时器,它可以按照指定的时间间隔或者指定的时间执行一个事件. 指定时间间隔是指按特定的时间间隔,如每1分钟.每10分钟.每1个小时等执行指定事件: 指定时间是指每小时的第30分 ...

  6. Android判断当前系统时间是否在指定时间的范围内(免消息打扰)

    /** * 判断当前系统时间是否在指定时间的范围内 * * @param beginHour * 开始小时,例如22 * @param beginMin * 开始小时的分钟数,例如30 * @para ...

  7. sql语句延时执行或者是指定时间执行

    --使用waitfor语句延迟或暂停程序的执行 --waitfor{delay'time'|time 'time'} delay是指间隔时间 最长到24小时 time是指定时间执行 waitfor d ...

  8. java获取系统指定时间年月日

    java获取系统指定时间年月日 private String setDateTime(String falg) { Calendar c = Calendar.getInstance(); c.set ...

  9. s实现指定时间自动跳转到某个页面

    --js实现指定时间自动跳转到某个页面 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" &quo ...

随机推荐

  1. C++重载流插入和流输出运算符

    demo: /* Name: 重载输入输出流运算符使力代码 Copyright: qianshou Author: zhaozhe Date: 07/12/13 00:11 Description: ...

  2. 杭电acm 1108题

    这是一道求两个整数最大公倍数的问题,题目比较简单.... 直接使用穷举法计算,数据不是很大.... #include "iostream" using namespace std; ...

  3. 算法Sedgewick第四版-第1章基础-018一解决不能声明泛型数组的两咱方法(强转或反射)

    1. /****************************************************************************** * Compilation: ja ...

  4. 关于Java中hashCode方法的实现源码

    首先来看一下String中hashCode方法的实现源码. public int hashCode() { int h = hash; if (h == 0 && value.leng ...

  5. python--tkinter桌面编程开发--记事本

    什么是TK\Tkinter Tkinter是连接Python和TK图形库的一个纽带(接口) Hello Tkinter from tkinter import * root=Tk() #tk类的一个实 ...

  6. Algorithms - Insertion sort

    印象 图1 插入排序过程 思想 插入排序(Insertion Sort)的主要思想是不断地将待排序的元素插入到有序序列中,是有序序列不断地扩大,直至所有元素都被插入到有序序列中. 分析 时间复杂度: ...

  7. C#使用Newtonsoft.Json操作json

    1.下载 Newtonsoft.Json 右键引用,选择 管理NuGet程序包,选择浏览,输入log4net,然后点击下载 2.json数据的组装与解析 public class Class { pu ...

  8. linux 进程间通信机制(IPC机制)一总览

    1.作用:进程间通信机制(Inter Process Communication,IPC),这些IPC机制的存在使UNIX在进程通信领域手段相当丰富,也使得程序员在开发一个由多个进程协作的任务组成的系 ...

  9. metasploit 读书笔记-EXPLOITATION

    一、渗透攻击基础 1.常用命令 show exploits 显示Meta框架中所有可用的渗透攻击模块。 show options 显示模块所需要的各种参数 back 返回Meta的上一个状态 sear ...

  10. 「BZOJ 3529」「SDOI 2014」数表「莫比乌斯反演」

    题意 有一张 \(n\times m\) 的数表,其第\(i\)行第\(j\)列的数值为能同时整除\(i\)和\(j\)的所有自然数之和. \(T\)组数据,询问对于给定的 \(n,m,a\) , 计 ...