在mysql 使用binlog日志
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在mysql 使用binlog日志相关的知识,希望对你有一定的参考价值。
一. 利用binlog恢复库表
策略:
1.启用binlog日志
2.创建db1库tb1表,插入3条记录
3.删除tb1表中刚插入的3条记录
4.使用mysqlbinlog恢复删除的3条记录
步骤一:启用binlog日志
1)调整/etc/my.cnf配置,并重启服务
[mysqld]
......
log_bin=logdir
server_id=50
binlog_format=mixed
......
[[email protected] ~]# systemctl restart mysqld
2)确认binlog日志文件
新启用binlog后,每次启动MySQl服务都会新生成一份日志文件:
[[email protected] ~]# ls /var/lib/mysql/logdir.*
/var/lib/mysql/logdir.000001 /var/lib/mysql/logdir.index
其中logdir.index文件记录了当前保持的二进制文件列表:
重启MySQL服务程序,或者执行SQL操作“FLUSH LOGS;”,会生成一份新的日志:
[[email protected] ~]# cat /var/lib/mysql/logdir.index
./logdir.000001
[[email protected] ~]# systemctl restart mysqld
[[email protected] ~]# cat /var/lib/mysql/logdir.index
./logdir.000001
./logdir.000002
步骤二:利用binlog日志重做数据库操作
1)执行数据库表添加操作
创建db1·库tb1表,表结构自定义:
mysql> create database db1;
Query OK, 1 row affected (0.11 sec)
mysql> create table db1.tb1 (
-> id tinyint,
-> name char(18)
-> );
Query OK, 0 rows affected (0.68 sec
mysql> insert into db1.tb1 values(
-> 1,"yangmi"),
-> (2,"tangyuan"),
-> (3,"liuyan");
Query OK, 3 rows affected (0.13 sec)
Records: 3 Duplicates: 0 Warnings: 0
mysql> select * from db1.tb1;
+------+----------+
| id | name |
+------+----------+
| 1 | yangmi |
| 2 | tangyuan |
| 3 | liuyan |
+------+----------+
3 rows in set (0.00 sec)
2)删除前一步添加的3条表记录
执行删除所有表记录操作:
mysql> delete from db1.tb1;
Query OK, 3 rows affected (0.14 sec)
mysql> select * from db1.tb1;
Empty set (0.00 sec)
步骤三:通过binlog日志恢复表记录
binlog会记录所有的数据库、表更改操作,所以可在必要的时候重新执行以前做过的一部分数据操作,但对于启用binlog之前已经存在的库、表数据将不适用。
根据上述“恢复被删除的3条表记录”的需求,应通过mysqlbinlog工具查看相关日志文件,找到删除这些表记录的时间点,只要恢复此前的SQL操作(主要是插入那3条记录的操作)即可。
[[email protected] ~]# cat /var/lib/mysql/logdir.index
./logdir.000001
./logdir.000002
mysql> show variables like "binlog_format";
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| binlog_format | MIXED |
+---------------+-------+
1 row in set (0.01 sec)
2) 执行指定Pos节点范围内的sql命令恢复数据
mysql> create table db1.tb2 ( id tinyint, name char(12) );
Query OK, 0 rows affected (0.40 sec)
alert user [email protected] identified by "Wjc_2018";
以上是关于在mysql 使用binlog日志的主要内容,如果未能解决你的问题,请参考以下文章