首页 > 数据库 > MySQL > 正文

Mysql实现增量恢复的方法详解

2024-07-24 12:50:06
字体:
来源:转载
供稿:网友

实验介绍

增量恢复一般适用的场景:

1、人为的sql语句破坏了数据库

2、在进行下一次完全备份之前发生系统故障导致数据库数据丢失

3、在主从架构中,主库数据发生了故障

丢失完全备份之后更改的数据的恢复步骤

1、首先做一个完全备份,确保生成完全备份的sql文件。

mysql> select * from yx; #完全备份前数据库+----------+--------+| name | score |+----------+--------+| zhangsan | 100.00 || lisi | 90.00 || wangwu | 80.00 || zhaoliu | 99.00 |+----------+--------+4 rows in set (0.00 sec)[root@promote data]# mysqldump -u root -p test > /opt/test.sql #对数据库完全备份

2、使用flush-logs生成新的二进制日志文件,用以保存之后的数据库操作语句。

[root@promote data]# mysqladmin -u root -p flush-logs  #生成二进制文件
Enter password:
[root@promote data]# ls
auto.cnf        ibdata1      ib_logfile1  mysql             mysql-bin.index     sys
ib_buffer_pool  ib_logfile0  ibtmp1       mysql-bin.000001  performance_schema  test

3、在数据库中插入一条记录,再执行flush-logs操作,生成新的二进制增量备份文件。

mysql> insert into yx(name,score) values('tom',87);
Query OK, 1 row affected (0.00 sec)

mysql> select * from yx;
+----------+--------+
| name     | score  |
+----------+--------+
| zhangsan | 100.00 |
| lisi     |  90.00 |
| wangwu   |  80.00 |
| zhaoliu  |  99.00 |
| tom      |  87.00 |
+----------+--------+
5 rows in set (0.00 sec)
[root@promote data]# mysqladmin -u root -p flush-logs  #生成二进制文件
Enter password:
[root@promote data]# ls
auto.cnf        ibdata1      ib_logfile1  mysql             mysql-bin.000002  performance_schema  test
ib_buffer_pool  ib_logfile0  ibtmp1       mysql-bin.000001  mysql-bin.index   sys

4、用delete删除刚才插入的数据。模拟完全备份后数据丢失。

mysql> delete from yx where name='tom';
Query OK, 1 row affected (0.00 sec)

mysql> select * from yx;
+----------+--------+
| name     | score  |
+----------+--------+
| zhangsan | 100.00 |
| lisi     |  90.00 |

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表