在mysql 使用binlog日志
admin
2023-04-10 12:43:23
0

一. 利用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
......

[root@MySQL50 ~]# systemctl restart mysqld

2)确认binlog日志文件
新启用binlog后,每次启动MySQl服务都会新生成一份日志文件:
[root@MySQL50 ~]# ls /var/lib/mysql/logdir.*
/var/lib/mysql/logdir.000001 /var/lib/mysql/logdir.index
其中logdir.index文件记录了当前保持的二进制文件列表:
重启MySQL服务程序,或者执行SQL操作“FLUSH LOGS;”,会生成一份新的日志:

[root@MySQL50 ~]# cat /var/lib/mysql/logdir.index
./logdir.000001
[root@MySQL50 ~]# systemctl restart mysqld
[root@MySQL50 ~]# 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条记录的操作)即可。

[root@MySQL50 ~]# 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 root@localhost identified by "Wjc_2018";

相关内容

热门资讯

今日重大消息“乐乐上海麻将开挂... 网上科普关于“乐乐上海麻将有没有挂”话题很是火热,小编也是针对乐乐上海麻将作*弊开挂的方法以及开挂对...
今日重大通报“点点四川长牌怎么... 您好:点点四川长牌这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款...
【今日要闻】“新超圣炸/金/花... 家人们!今天小编来为大家解答新超圣炸/金/花透视挂怎么安装这个问题咨询软件客服徽9784099的挂在...
终于明白“朋友贵州麻将有没有挂... 终于明白“朋友贵州麻将有没有挂?”(透视曝光猫腻)您好,朋友贵州麻将这个游戏其实有挂的,确实是有挂的...
【今日要闻】“炫龙牛牛可以开挂... 【今日要闻】“炫龙牛牛可以开挂吗?”(其实是有挂)您好,炫龙牛牛这个游戏其实有挂的,确实是有挂的,需...
终于了解“圣盛宜昌花牌是不是有... 您好:圣盛宜昌花牌这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款...
今日重大消息“新八戒是不是有挂... 今日重大消息“新八戒是不是有挂?”(外卦神器下载)您好,新八戒这个游戏其实有挂的,确实是有挂的,需要...
玩家最新攻略“乐游510k到底... 有 亲,根据资深记者爆料乐游510k是可以开挂的,确实有挂(咨询软件无需...
重磅消息“普通扑克三公保庄大是... 家人们!今天小编来为大家解答普通扑克三公保庄大透视挂怎么安装这个问题咨询软件客服徽4282891的挂...
今日重大消息“熊猫四川麻将辅助... 网上科普关于“熊猫四川麻将有没有挂”话题很是火热,小编也是针对熊猫四川麻将作*弊开挂的方法以及开挂对...