mysqlbinlog制定区间恢复数据
admin
2023-05-20 13:22:57
0

一个有意思的场景:

mysql> show databases;

+--------------------+

| Database           |

+--------------------+

| information_schema |

| ZLECUBE            |

| log                |

| mysql              |

| performance_schema |

+--------------------+

5 rows in set (0.00 sec)


mysql> 

mysql> 

mysql> create database test;

Query OK, 1 row affected (0.00 sec)


mysql> 

mysql> use test;

Database changed

mysql> 

mysql> 

mysql> create table aa(id int);

Query OK, 0 rows affected (0.03 sec)


mysql> 

mysql> flush logs;

Query OK, 0 rows affected (0.00 sec)


mysql> \q

Bye

root@debian:/var/lib/mysql/log/binlog# ls -l

total 56

-rw-rw---- 1 mysql mysql 150 Feb  3 19:25 mysql-bin.000017

-rw-rw---- 1 mysql mysql 150 Feb  4 19:25 mysql-bin.000018

-rw-rw---- 1 mysql mysql 150 Feb  5 19:25 mysql-bin.000019

-rw-rw---- 1 mysql mysql 150 Feb  6 19:25 mysql-bin.000020

-rw-rw---- 1 mysql mysql 150 Feb  7 15:04 mysql-bin.000021

-rw-rw---- 1 mysql mysql 314 Feb  7 19:25 mysql-bin.000022

-rw-rw---- 1 mysql mysql 150 Feb  8 19:25 mysql-bin.000023

-rw-rw---- 1 mysql mysql 150 Feb  9 19:25 mysql-bin.000024

-rw-rw---- 1 mysql mysql 150 Feb 10 19:25 mysql-bin.000025

-rw-rw---- 1 mysql mysql 150 Feb 11 19:25 mysql-bin.000026

-rw-rw---- 1 mysql mysql 150 Feb 12 19:25 mysql-bin.000027

-rw-rw---- 1 mysql mysql 319 Feb 13 15:08 mysql-bin.000028

-rw-rw---- 1 mysql mysql 107 Feb 13 15:08 mysql-bin.000029

-rw-rw---- 1 mysql mysql 559 Feb 13 15:08 mysql-bin.index



root@debian:/var/lib/mysql/log/binlog# mysqlbinlog mysql-bin.000028

找到如下的信息:


# at 107

#170213 15:08:21 server id 1  end_log_pos 190 Query thread_id=1435 exec_time=0 error_code=0

SET TIMESTAMP=1486969701/*!*/;

SET @@session.pseudo_thread_id=1435/*!*/;

SET @@session.foreign_key_checks=1, @@session.sql_auto_is_null=0, @@session.unique_checks=1, @@session.autocommit=1/*!*/;

SET @@session.sql_mode=0/*!*/;

SET @@session.auto_increment_increment=1, @@session.auto_increment_offset=1/*!*/;

/*!\C utf8 *//*!*/;

SET @@session.character_set_client=33,@@session.collation_connection=33,@@session.collation_server=8/*!*/;

SET @@session.lc_time_names=0/*!*/;

SET @@session.collation_database=DEFAULT/*!*/;

create database test

/*!*/;

# at 190

#170213 15:08:39 server id 1  end_log_pos 276 Query thread_id=1435 exec_time=1 error_code=0

use `test`/*!*/;

SET TIMESTAMP=1486969719/*!*/;

create table aa(id int)

/*!*/;

# at 276

#170213 15:08:56 server id 1  end_log_pos 319 Rotate to mysql-bin.000029  pos: 4

DELIMITER ;

# End of log file




删除刚刚的test库


mysql> drop database test;

Query OK, 1 row affected (0.01 sec)


mysql> \q

Bye



现在进行恢复:


root@debian:/var/lib/mysql/log/binlog# mysqlbinlog --start-position=190 --stop-position=319  mysql-bin.000028 |mysql -uroot -pxxx

root@debian:/var/lib/mysql/log/binlog# 


mysql> show tables;

+----------------+

| Tables_in_test |

+----------------+

| aa             |

+----------------+

1 row in set (0.00 sec)


mysql> 


已恢复。





可以重复恢复。


mysql> select count(*) from aa;

+----------+

| count(*) |

+----------+

|        4 |

+----------+



root@debian:/var/lib/mysql/log/binlog# mysqlbinlog --start-position=793  --stop-position=1093  mysql-bin.000029 |mysql -uroot -pxxx

root@debian:/var/lib/mysql/log/binlog# 

只恢复从日志位置793到1093的信息,这里面有有两个插入记录。


mysql> select count(*) from aa;

+----------+

| count(*) |

+----------+

|        6 |

+----------+

1 row in set (0.00 sec)



此外,还可以--start-datetime --stop-datetime来指定恢复时间。


相关内容

热门资讯

47年,一条产业链托起一台冠军... 从嘉陵CJ50到张雪机车820RR——47年,一条产业链托起一台冠军摩托车(经济聚焦)本报记者 王欣...
核电站遭袭,阿联酋与卡塔尔、约... 当地时间17日,阿联酋强烈谴责针对位于宰夫拉地区巴拉卡核电站外围一台发电机的袭击。此次袭击由一架从西...
没处休、没空休、不敢休,保洁员... 一些商场、写字楼没有设置工间休息室,他们没空休息、无处休息——保洁员该在哪儿歇脚(金台视线)本报记者...
官方通报柳州5.2级地震:3人... 据中国地震台网正式测定,2026年5月18日00时21分,在广西柳州市柳南区发生5.2级地震。在此前...
广西柳州发生5.2级地震,已致... 新华社南宁5月18日电(记者农冠斌、杨驰)5月18日0时21分,广西柳州市柳南区发生5.2级地震,震...
国家信息光电子创新中心成功研发... 5月15日消息,据“中国光谷”公众号,国家信息光电子创新中心(NOEIC)近日成功自主研发了一款超宽...
特朗普称如果伊朗不迅速行动,“... 新华社华盛顿5月17日电(记者徐剑梅 黄强)美国总统特朗普17日在社交媒体发文称,如果伊朗不迅速行动...
柳州5.2级地震致楼房倒塌,店... 据中国地震台网消息,5月18日00时21分在广西柳州市柳南区发生5.2级地震,震源深度8千米。有网友...
“华南第一商圈”再升级!全国首... 5月16日,“万兆AI惠商,联通美好未来”2026年517电信日暨中国联通品牌与产品广东宣传推广会在...
原创 3... 如果今年618你手里预算在3000多元,又特别看重拍照,我反而不建议只盯着那些刚发布、热度很高的新机...