首页
Web开发
Windows程序
编程语言
数据库
移动开发
系统相关
微信
其他好文
会员
首页
>
数据库
> 详细
MySQL 增量备份与还原
时间:
2018-09-19 11:39:23
阅读:
243
评论:
0
收藏:
0
[点我收藏+]
标签:
com
增加
操作
sha
数据库
str
vim
oca
虚拟
说明:
所谓增量备份,就是备份自上一次备份之后增加或改变的文件或内容。然而MySQL没有提供直接的增量备份方法,但是却可以通过MySQL的二进制日志间接实现增量备份。下面有关操作方法进行测试。
.
.
实验环境:装有MySQL 5.7 数据库的CentOS7虚拟机一台
.
.
实验步骤如下:
.
.
1 .进入配置文件添加二进制日志
vim /etc/my.cnf
[mysqld]
在其中插入二进制日志
log_bin=mysql-bin #二进制日志
.
.
2 . 然后重启数据库,到日志文件目录下查看一下
.
.
3 . 新建数据库,并在其中新建数据表,写入数据
.
.
4 .重新生成一个日志文件,这样刚才的操作步骤都会保存在第一个二进制文件中
mysqladmin -u root -p flush-logs#重新生成二进制文件
.
.
5 . 将刚才新建的数据库删除,然后使用恢复命令恢复数据库
mysqlbinlog --no-defaults mysql-bin.000001 | mysql -u root -p #日志文件恢复
.
.
6 . 可以查看到数据库已经被恢复好
.
.
7 .接下来,测试误操作之后的恢复(两种方法,一是利用时间点,二是利用位置点)先进行时间点的操作
在表中插入数据
下一步,删除表中一条数据(误操作)
然后再插入一条数据
这样,误操作的一条命令已经被覆盖
.
.
8 . 重新生成一个二进制日志
mysqladmin -u root -p flush-logs#创建新日志
.
.
9 . mysqlbinlog --no-defaults --base64-output=decode-rows -v mysql-bin.000002#64位解码查看日志文件,防乱码
在其中需要找到两个时间点
(1) 删除数据的时间点
(2) 删除之后下一步正确操作时间点
.
.
10 . 找到两个时间点之后,用这两个时间点进行恢复
mysqlbinlog --no-defaults --stop-datetime=‘2018-09-03 16:38:08‘ /usr/local/mysql/data/mysql-bin.000002 | mysql -u root -p#恢复到错误时间点
mysqlbinlog --no-defaults --start-datetime=‘2018-09-03 16:39:08‘ /usr/local/mysql/data/mysql-bin.000002 | mysql -u root -p#从下一个正确时间点恢复
.
.
11 . 这样被误删除的数据就恢复好了
.
.
12 . 下面根据位置点,再进行恢复
同样把数据恢复到误删除
.
.
13 . mysqlbinlog --no-defaults --base64-output=decode-rows -v mysql-bin.000002 #64位解码查看日志文件,防乱码
找到错误点执行的命令后,复制上一次可正确执行的位置(at后面就是位置号)
然后找到下一次可执行的命令,同样复制上一次可正确执行的位置
.
.
14 . 利用位置点进行恢复
mysqlbinlog --no-defaults --stop-datetime=‘1950‘ /usr/local/mysql/data/mysql-bin.000002 | mysql -u root -p#恢复到错误时间点
mysqlbinlog --no-defaults --start-datetime=‘2223‘ /usr/local/mysql/data/mysql-bin.000002 | mysql -u root -p#从下一个正确时间点恢复
最后查看结果,测试完成
MySQL 增量备份与还原
标签:
com
增加
操作
sha
数据库
str
vim
oca
虚拟
原文地址:http://blog.51cto.com/13756925/2176945
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年07月29日 (22)
2021年07月28日 (40)
2021年07月27日 (32)
2021年07月26日 (79)
2021年07月23日 (29)
2021年07月22日 (30)
2021年07月21日 (42)
2021年07月20日 (16)
2021年07月19日 (90)
2021年07月16日 (35)
周排行
更多
数据库进阶
2021-07-29
在 Oracle 数据库中执行 SQL 语句遇到特殊字符的转义方式
2021-07-28
Windows Logstash同步 Sqlserver 到Elasticsearch
2021-07-26
mysql数据库(11):恢复数据
2021-07-26
mysql数据库(9):常用查询的例子
2021-07-26
SQLAlchemy 多对多
2021-07-26
ClickHouse的JDBC连接
2021-07-26
Apache HBase 1.7.1 发布,分布式数据库
2021-07-26
数据库常用架构和同步工作原理
2021-07-26
MySQL数据库设计规范(仅供参考)
2021-07-26
友情链接
兰亭集智
国之画
百度统计
站长统计
阿里云
chrome插件
新版天听网
关于我们
-
联系我们
-
留言反馈
© 2014
mamicode.com
版权所有 联系我们:gaon5@hotmail.com
迷上了代码!