时间:2021-07-01 10:21:17 帮助过:11人阅读
查看当前的类型:
show variables like ‘binlog_format‘
/etc/my.cnf 里面的binlog_format参数
全备+恢复部分binlog日志
mysqldump -uroot -pfjselinfgsiengiseg test3 > /data1/test3.sql.
SQL1:update student set age=21 where id=4;
SQL2:update student set age=22 where id=5;
这时执行了两个sql,对应的是两个事务。
如果我们想把数据库状态恢复到执行SQL1之后
要刷新日志后,我们才能查看日志,找到需要恢复的binlog
执行:
flush logs;
找到binlog日志:/var/lib/mysql/mysql-bin.000031
mysql执行:
show binlog events in "mysql-bin.000031"
找到刚才的两次事务
|
mysql-bin.000031 | 6622 | Query | 1 | 6691 | BEGIN |
| mysql-bin.000031 | 6691 | Table_map | 1 | 6745 | table_id: 308 (test3.student) |
| mysql-bin.000031 | 6745 | Update_rows | 1 | 6801 | table_id: 308 flags: STMT_END_F |
| mysql-bin.000031 | 6801 | Xid | 1 | 6828 | COMMIT /* xid=6771600 */ |
| mysql-bin.000031 | 6828 | Query | 1 | 6897 | BEGIN |
| mysql-bin.000031 | 6897 | Table_map | 1 | 6951 | table_id: 308 (test3.student) |
| mysql-bin.000031 | 6951 | Update_rows | 1 | 7007 | table_id: 308 flags: STMT_END_F |
| mysql-bin.000031 | 7007 | Xid | 1 | 7034 | COMMIT /* xid=6771607 */ |
| mysql-bin.000031 | 7034 | Rotate | 1 | 7077 | mysql-bin.000032;pos=4 |
+------------------+-------+--------------+-------------+---------------+-----------------------------------------------------------------------------+
BEGIN是开始事务
COMMIT是提交事务
所以我们需要恢复的是6622 到 6828
把旧的test3数据库改名,或者删除。建议先备份
drop database test3;
创建数据库test3
create database test3;
导入全备份
source /data1/test3.sql;
恢复部分binlog日志
mysqlbinlog --start-position=6622 --stop-position=6828 --database=test3 /var/lib/mysql/mysql-bin.000031 |mysql -uroot -pfjselinfgsiengiseg -D test3
mysqlbinlog 命令会把对应的binlog日志转换为sql语句,导出来,然后通过mysql命令来执行sql语句
恢复前的数据:
mysql root@localhost:test3> select * from student;
+------+--------+-------+---------+
| id | name | age | class |
|------+--------+-------+---------|
| 4 | 2 | 20 | B |
| 5 | 2 | 21 | B |
+------+--------+-------+---------+
恢复后的数据
mysql root@localhost:test3> select * from student;
+------+--------+-------+---------+
| id | name | age | class |
|------+--------+-------+---------|
| 4 | 2 | 21 | B |
| 5 | 2 | 21 | B |
+------+--------+-------+---------+
可以看到,SQL1执行了,SQL2没有执行。
未经允许,请不要转载
使用全备+binlog日志恢复数据库
标签:mysql-bin 备份 mat upd 转换 混合 通过 comm 服务器