mysql 开发进阶篇系列 43 逻辑备份与恢复(mysqldump 的基于时间和位置的不完全恢复)
一. 概述
在上篇讲到了逻辑备份,使用mysqldump工具来备份一个库,并使用完全恢复还原了数据库。在结尾也讲到了误操作是不能用完全恢复的。解决办法是:我们需要恢复到误操作之前的状态,然后跳过误操作语句。再恢复后面执行的语句,完成我们的恢复,这种恢复叫“不完全恢复”。在mysql 中,不完全恢复分为基于时间点的恢复和基于位置的恢复。
  1.1 基于时间点恢复步骤
    下面来模拟基于时间点恢复,操作步骤如下:
(1)先逻辑备份一个库。
(2)模拟用户操作一些数据。
(3)误操作发生,记住时间点。
(4)还原备份库。
(5)使用mysqlbinlog --stop-datetime恢复到误操作前的时间点。
(6)跳过误操作时间点,使用mysqlbinlog --start-datetime继续执行后面的binlog,完成恢复。
1.2 基于时间点恢复演示
下面以test库的testbackup表为例,该表有6条数据,如下图所示:
-- 共6条数据
SELECT * FROM testbackup
      
-- 当前log文件序号是:mysql-bin.000040
SHOW MASTER STATUS
步骤1:备份test库,先定位到/usr/local/mysql/data目录下,备份完成后此时的log文件序号mysql-bin.000041,备份脚本下图所示:
[root@hsr data]# pwd
/usr/local/mysql/data
[root@hsr data]# mysqldump -uroot -p --single-transaction -F test > test.dmp
Enter password:
[root@hsr data]# ls -l test.dmp
-rw-r--r-- root root 9月 : test.dmp
步骤2: 进行正常用户操作,新增了二条数据,此时表中共8条数据。
INSERT INTO testbackup VALUES(7,'田七')
INSERT INTO testbackup VALUES(8,'小康')
步骤3:误操作发生,删除了一条数据id为3的,此时表中共7条数据,误删除时间点是10:01分钟
DELETE FROM testbackup WHERE id=3
步骤4:还原数据库后,此时testbackup表只有最初的6条数据
[root@hsr data]# mysql -uroot -p test < test.dmp
Enter password:
步骤:5和6
-- 切换到binlog日志目录下
[root@hsr mysql]# pwd
/var/lib/mysql -- 恢复到误操作前的时间点
[root@hsr mysql]# mysqlbinlog --stop-datetime="2018-09-26 9:59:59" mysql-bin. | mysql -uroot -p
Enter password: -- 跳过误操作时间点,继续执行后面的binlog
[root@hsr mysql]# mysqlbinlog --start-datetime="2018-09-26 10:02:59" mysql-bin. | mysql -uroot -p
Enter password:
最后经过上面的步骤,误操作恢复完成了,最后查看该表的数据如下。
SELECT * FROM testbackup
      
1.3 基于位置的恢复
与时间点的恢复不同,基于位置的恢复更加精确,因为一个时间点可能有很多条sql语句同时执行。下面模拟操作步骤:1,2,3,4操作步骤与上面相同。
    (5) 分析误位置行号
	      方法1:对于大日志文件,将误操作时间点范围内(2-5分钟)的binlog日志复制到另一个小文件中,方便查找分析位置行号。
	      方法2:对于小日志文件,使用SHOW BINLOG EVENTS 查看误操作位置行号,前提是需要在my.cnf中设置binlog_rows_query_log_events=1
    (6) 使用mysqlbinlog --stop-position恢复到误操作前的位置号。
    (7) 跳过误操作位置号,使用mysqlbinlog --start-position继续执行后面的binlog,完成恢复。
1.4基于位置的恢复演示
-- 共8条数据
SELECT * FROM testbackup
-- 当前mysql-bin.000041
SHOW MASTER STATUS
步骤1:备份test库,先定位到/usr/local/mysql/data目录下,备份完成后此时的log文件序号mysql-bin.000042,备份脚本下图所示:
[root@hsr data]# pwd
/usr/local/mysql/data
[root@hsr data]# mysqldump -uroot -p --single-transaction -F test > test2.dmp
Enter password:
[root@hsr data]# ls -l test2.dmp
-rw-r--r-- 1 root root 321286 9月 26 14:02 test2.dmp
步骤2:进行正常用户操作,新增了二条数据,此时表中共10条数据。
INSERT INTO testbackup VALUES(9,'小王')
INSERT INTO testbackup VALUES(10,'小李')
      
    步骤3:误操作发生,删除了一条数据id为5的,此时表中共9条数据,误删除时间点是14:06分钟
DELETE FROM testbackup WHERE id=5
步骤4:还原数据库后,此时testbackup只有最初的8条数据
[root@hsr data]# mysql -uroot -p test < test2.dmp
Enter password:
      
    步骤5:分析误位置位置行号
-- 方法1:
[root@hsr mysql]# pwd
/var/lib/mysql
[root@hsr mysql]# touch tmp.sql
mysqlbinlog --base64-output=decode-row -v --start-datetime="2018-09-26 14:05:59" --stop-datetime="2018-09-26 14:07:59" mysql-bin. > tmp.sql
[root@hsr mysql]# more tmp.sql
    查看tmp.sql文件,找到删除的时间是14:06:22时,开始位置是1077,结束位置是1155。
      
-- 方法2:
SHOW BINLOG EVENTS IN 'mysql-bin.000042';
    这里找到真正删除行是1077, commit提交后下一行1155。
      
步骤6-7:
[root@hsr mysql]# mysqlbinlog --stop-position="" mysql-bin. | mysql -uroot -p
WARNING: The range of printed events ends with a row event or a table map event that does not have the STMT_END_F flag set.
This might be because the last statement was not fully written to the log, or because you are using a --stop-position or --stop-datetime
that refers to an event in the middle of a statement. The event(s) from the partial statement have not been written to output.
Enter password:
[root@hsr mysql]# mysqlbinlog --start-position="" mysql-bin. | mysql -uroot -p
Enter password:
[root@hsr mysql]#
最后经过上面的步骤,误操作恢复完成了,最后查看该表的数据如下。
SELECT * FROM testbackup
      
mysql 开发进阶篇系列 43 逻辑备份与恢复(mysqldump 的基于时间和位置的不完全恢复)的更多相关文章
- mysql 开发进阶篇系列 42  逻辑备份与恢复(mysqldump 的完全恢复)
		一.概述 在作何数据库里,备份与恢复都是非常重要的.好的备份方法和备份策略将会使得数据库中的数据更加高效和安全.对于DBA来说,进行备份或恢复操作时要考虑的因素大概有如下: (1) 确定要备份的表的存 ... 
- mysql 开发进阶篇系列 47 物理备份与恢复(xtrabackup 的完全备份恢复,恢复后重启失败总结)
		一. 完全备份恢复说明 xtrabackup二进制文件有一个xtrabackup --copy-back选项,它将备份复制到服务器的datadir目录下.下面是通过 --target-dir 指定完全 ... 
- mysql 开发进阶篇系列 46 物理备份与恢复( xtrabackup的 选项说明,增加备份用户,完全备份案例)
		一. xtrabackup 选项说明 在操作xtrabackup备份与恢复之前,先看下该工具的选项,下面记录了xtrabackup二进制文件的部分命令行选项,后期把常用的选项在补上.点击查看xtrab ... 
- mysql 开发进阶篇系列 48 物理备份与恢复(xtrabackup 的增量备份与恢复,以及备份总结)
		一.增量备份概述 xtrabackup 和innobackupex 二个工具都支持增量备份,这意味着能复制自上次备份以来更改的数据.可以在每个完整备份之间执行许多增量备份,因此,您可以设置一个备份 ... 
- mysql 开发进阶篇系列 45  物理备份与恢复(xtrabackup 安装,用户权限,配置)
		一. 安装说明 安装XtraBackup 2.4 版本有三种方式: (1) 存储库安装Percona XtraBackup(推荐) (2 )下载的rpm或apt包安装Percona XtraBacku ... 
- mysql 开发进阶篇系列 44 物理备份与恢复( 热备份xtrabackup 工具介绍)
		一.概述 物理备份和恢复又分为冷备份和热备份.与逻辑备份相比,它最大优点是备份和恢复的速度更快.因为物理备份的原理都是基于文件的cp. 1.1 冷备份 冷备份就是停掉数据库服务.这种物理备份一般很少使 ... 
- mysql 开发进阶篇系列 55 权限与安全(安全事项 )
		一. 操作系统层面安全 对于数据库来说,安全很重要,本章将从操作系统和数据库两个层面对mysql的安全问题进行了解. 1. 严格控制操作系统账号和权限 在数据库服务器上要严格控制操作系统的账号和权限, ... 
- mysql 开发进阶篇系列 20 MySQL Server(innodb_lock_wait_timeout,innodb_support_xa,innodb _log_*)
		1. innodb_lock_wait_timeout mysql 可以自动监测行锁导致的死锁并进行相应的处理,但是对于表锁导致的死锁不能自动监测,所以该参数主要用于,出现类似情况的时候等待指定的时间 ... 
- mysql 开发进阶篇系列 10 锁问题 (相同索引键值或同一行或间隙锁的冲突)
		1.使用相同索引键值的冲突 由于mysql 的行锁是针对索引加的锁,不是针对记录加的锁,所以虽然是访问不同行的记录,但如果是使用相同的索引键,是会出现锁冲突的.设计时要注意 例如:city表city_ ... 
随机推荐
- 使用Python完成排序(快排法、归并法)
			class Sort(object): def quick_sort(self, ls): self.quick_sort_helper(ls, 0, len(ls) - 1) return ls d ... 
- AHOI——Day1个人感悟
			今天,是个bilibili的日子.(嗯?什么意思?) 洛谷已经尽力了: 于是我带着洛谷的祝福,来到了AHOI的考场--合肥一中. 其实我是考完才签到的,我一大早五点多就起来了,到考场后,在肯德基吃了早 ... 
- Unity2018 VS2017打开CS脚本,提示全红及无法加载工程等问题解决
			VS2017用的比较老的版本,因为当时下载了离线文件,所以可以离线安装,现在看来是没有必要的,占硬盘空间不说,不更新VS IDE,Unity高版本还有问题. 主要问题在于,我之前一直用Unity201 ... 
- JAVA 8 主要新特性 ----------------(五)Lambda方法引用与构造器引用
			一.Lambda方法引用 当要传递给Lambda体的操作,已经有实现的方法了,可以使用方法引用!(实现抽象方法的参数列表,必须与方法引用方法的参数列表保持一致!) 方法引用: 使用操作符 “::” 将 ... 
- SpringCloud-分布式配置中心(基于SpringBoot2.X)
			一.配置中心的作用:可以将多种应用的配置进行集中式的管理,将这些配置统一存放到git或svn里面存储: 二.搭建SpringCloud-Config-Server 2.1如图后续步骤勾选Config ... 
- MyBatis配置C3P0连接池
			一.导包 c3p0包 mybatis包 数据库的连接包 二.继承UnpooledDataSourceFactory的类 Mybatis 没有帮开发者实现 c3p0 数据库连接池,故需要使用者自 ... 
- 前端基础之 html
			---恢复内容开始--- web服务本质 import socket sock=socket.socket() sock.bind(()) sock.listen() where True: conn ... 
- Gitee(码云)、Github同时配置ssh key
			一.cd ~/.ssh 二.通过下面的命令,依次生成两个平台的key $ ssh-keygen -t rsa -C "xxxxxxx@qq.com" -f "github ... 
- Shader_ShaderForge_NGUI_流光&波纹&消融
			Shader篇 总结:总算解决了NGUI中Shader不能实时更改的问题,原来NGUI中的Texture组件提供了OnRender代码示例如下 /*************************** ... 
- grep 笔记
			-a :将 binary 文件以 text 文件的方式搜寻数据-c :计算找到 '搜寻字符串' 的次数-i :忽略大小写的不同,所以大小写视为相同-n :顺便输出行号-v :反向选择,亦即显示出没有 ... 
