MySQL模拟:线上误update的恢复
生活随笔
收集整理的這篇文章主要介紹了
MySQL模拟:线上误update的恢复
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
作為DBA,細心、沉穩是首要的基本素質。不過總有那么一會心煩意亂或者開發同學出現誤操作之類的。。。這里模擬一個誤update操作,然后恢復。
如果開發同學有誤操作之后最好先別亂動生產環境,需要記錄幾個信息給DBA同學來恢復數據。
1:binlog_format、autocommit、binlog位置、誤操作的時間點
mysql> SHOW VARIABLES LIKE '%binlog_format%'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | binlog_format | ROW | +---------------+-------+ 1 row in set (0.00 sec)mysql> SHOW MASTER STATUS \G *************************** 1. row ***************************File: binlog.000048Position: 442Binlog_Do_DB: Binlog_Ignore_DB: 1 row in set (0.00 sec) 時間點大約在2015年6月29日 16:50:00 - 2015年6月29日 17:50:00之間 mysql> SHOW VARIABLES LIKE '%autocommit%'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | autocommit | OFF | +---------------+-------+ 1 row in set (0.00 sec)
2:如果在一個事物內的操作,同時autocommit是off的話,可以直接嘗試回滾。看看是否可以恢復過來。
3:原始數據
mysql> select * from t1.t1; +------+------+ | id1 | name | +------+------+ | 8 | u11 | | 8 | u12 | | 8 | u13 | | 8 | u14 | | 8 | u15 | | 8 | name | | 8 | name | | 8 | name | | 8 | name | +------+------+ 9 rows in set (0.00 sec)誤操作之后
mysql> update t1.t1 set id1 = 10; Query OK, 9 rows affected (0.00 sec) Rows matched: 9 Changed: 9 Warnings: 0mysql> commit; Query OK, 0 rows affected (0.01 sec)
恢復開始:
1:找到當前寫入的binlog信息:
mysql> SHOW MASTER STATUS \G *************************** 1. row ***************************File: binlog.000048Position: 777Binlog_Do_DB: Binlog_Ignore_DB: 1 row in set (0.00 sec)2:估計誤操作的時間點:2015-06-29 16:50:00和2015-06-29 17:20:00?之間,
3:另外開一個窗口解析binlog
mysqlbinlog --start-datetime='2015-06-29 01:30:00' --stop-datetime='2015-06-29 02:10:00' -vv binlog.000048 [root@localhost mysqllog]# mysqlbinlog --start-datetime='2015-06-29 01:30:00' --stop-datetime='2015-06-29 02:10:00' -vv binlog.000048 /*!40019 SET @@session.max_insert_delayed_threads=0*/; /*!50003 SET @OLD_COMPLETION_TYPE=@@COMPLETION_TYPE,COMPLETION_TYPE=0*/; DELIMITER /*!*/; # at 4 #150629 1:44:39 server id 1 end_log_pos 107 Start: binlog v 4, server v 5.5.20-log created 150629 1:44:39 # Warning: this binlog is either in use or was not closed properly. BINLOG ' dwWRVQ8BAAAAZwAAAGsAAAABAAQANS41LjIwLWxvZwAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA AAAAAAAAAAAAAAAAAAAAAAAAEzgNAAgAEgAEBAQEEgAAVAAEGggAAAAICAgCAA== '/*!*/; # at 107 #150629 1:45:06 server id 1 end_log_pos 173 Query thread_id=7 exec_time=0 error_code=0 SET TIMESTAMP=1435567506/*!*/; SET @@session.pseudo_thread_id=7/*!*/; 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 latin1 *//*!*/; SET @@session.character_set_client=8,@@session.collation_connection=8,@@session.collation_server=33/*!*/; SET @@session.lc_time_names=0/*!*/; SET @@session.collation_database=DEFAULT/*!*/; BEGIN /*!*/; # at 173 # at 215 #150629 1:44:56 server id 1 end_log_pos 215 Table_map: `t1`.`t1` mapped to number 33 #150629 1:44:56 server id 1 end_log_pos 415 Update_rows: table id 33 flags: STMT_END_FBINLOG ' iAWRVRMBAAAAKgAAANcAAAAAACEAAAAAAAEAAnQxAAJ0MQACA/4C/jwD iAWRVRgBAAAAyAAAAJ8BAAAAACEAAAAAAAEAAv///AYAAAADdTEx/AgAAAADdTEx/AYAAAADdTEy /AgAAAADdTEy/AYAAAADdTEz/AgAAAADdTEz/AYAAAADdTE0/AgAAAADdTE0/AYAAAADdTE1/AgA AAADdTE1/AYAAAAEbmFtZfwIAAAABG5hbWX8BgAAAARuYW1l/AgAAAAEbmFtZfwGAAAABG5hbWX8 CAAAAARuYW1l/AYAAAAEbmFtZfwIAAAABG5hbWU= '/*!*/; ### UPDATE `t1`.`t1` ### WHERE ### @1=6 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u11' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u11' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=6 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u12' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u12' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=6 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u13' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u13' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=6 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u14' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u14' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=6 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u15' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u15' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=6 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=6 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=6 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=6 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ # at 415 #150629 1:45:06 server id 1 end_log_pos 442 Xid = 313 COMMIT/*!*/; # at 442 #150629 2:00:29 server id 1 end_log_pos 508 Query thread_id=7 exec_time=0 error_code=0 SET TIMESTAMP=1435568429/*!*/; BEGIN /*!*/; # at 508 # at 550 #150629 2:00:27 server id 1 end_log_pos 550 Table_map: `t1`.`t1` mapped to number 33 #150629 2:00:27 server id 1 end_log_pos 750 Update_rows: table id 33 flags: STMT_END_FBINLOG ' KwmRVRMBAAAAKgAAACYCAAAAACEAAAAAAAEAAnQxAAJ0MQACA/4C/jwD KwmRVRgBAAAAyAAAAO4CAAAAACEAAAAAAAEAAv///AgAAAADdTEx/AoAAAADdTEx/AgAAAADdTEy /AoAAAADdTEy/AgAAAADdTEz/AoAAAADdTEz/AgAAAADdTE0/AoAAAADdTE0/AgAAAADdTE1/AoA AAADdTE1/AgAAAAEbmFtZfwKAAAABG5hbWX8CAAAAARuYW1l/AoAAAAEbmFtZfwIAAAABG5hbWX8 CgAAAARuYW1l/AgAAAAEbmFtZfwKAAAABG5hbWU= '/*!*/; ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u11' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u11' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u12' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u12' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u13' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u13' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u14' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u14' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u15' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u15' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ # at 750 #150629 2:00:29 server id 1 end_log_pos 777 Xid = 318 COMMIT/*!*/; DELIMITER ; # End of log file ROLLBACK /* added by mysqlbinlog */; /*!50003 SET COMPLETION_TYPE=@OLD_COMPLETION_TYPE*/;
找到誤操作的update:
### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u11' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u11' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u12' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u12' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u13' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u13' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u14' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u14' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u15' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='u15' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### SET ### @1=10 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ ### UPDATE `t1`.`t1` ### WHERE ### @1=8 /* INT meta=0 nullable=1 is_null=0 */ ### @2='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */處理之后的誤操作語句
UPDATE `t1`.`t1` WHEREid1=8 /* INT meta=0 nullable=1 is_null=0 */name='u11' /* STRING(60) meta=65084 nullable=1 is_null=0 */ SETid1=10 /* INT meta=0 nullable=1 is_null=0 */name='u11' /* STRING(60) meta=65084 nullable=1 is_null=0 */ UPDATE `t1`.`t1` WHEREid1=8 /* INT meta=0 nullable=1 is_null=0 */name='u12' /* STRING(60) meta=65084 nullable=1 is_null=0 */ SETid1=10 /* INT meta=0 nullable=1 is_null=0 */name='u12' /* STRING(60) meta=65084 nullable=1 is_null=0 */ UPDATE `t1`.`t1` WHEREid1=8 /* INT meta=0 nullable=1 is_null=0 */name='u13' /* STRING(60) meta=65084 nullable=1 is_null=0 */ SETid1=10 /* INT meta=0 nullable=1 is_null=0 */name='u13' /* STRING(60) meta=65084 nullable=1 is_null=0 */ UPDATE `t1`.`t1` WHEREid1=8 /* INT meta=0 nullable=1 is_null=0 */name='u14' /* STRING(60) meta=65084 nullable=1 is_null=0 */ SETid1=10 /* INT meta=0 nullable=1 is_null=0 */name='u14' /* STRING(60) meta=65084 nullable=1 is_null=0 */ UPDATE `t1`.`t1` WHEREid1=8 /* INT meta=0 nullable=1 is_null=0 */name='u15' /* STRING(60) meta=65084 nullable=1 is_null=0 */ SETid1=10 /* INT meta=0 nullable=1 is_null=0 */name='u15' /* STRING(60) meta=65084 nullable=1 is_null=0 */ UPDATE `t1`.`t1` WHEREid1=8 /* INT meta=0 nullable=1 is_null=0 */name='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ SETid1=10 /* INT meta=0 nullable=1 is_null=0 */name='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ UPDATE `t1`.`t1` WHEREid1=8 /* INT meta=0 nullable=1 is_null=0 */name='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ SETid1=10 /* INT meta=0 nullable=1 is_null=0 */name='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ UPDATE `t1`.`t1` WHEREid1=8 /* INT meta=0 nullable=1 is_null=0 */name='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ SETid1=10 /* INT meta=0 nullable=1 is_null=0 */name='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */ UPDATE `t1`.`t1` WHEREid1=8 /* INT meta=0 nullable=1 is_null=0 */name='name' /* STRING(60) meta=65084 nullable=1 is_null=0 */根據對應的語句一句一句恢復即可。
?
?
《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀總結
以上是生活随笔為你收集整理的MySQL模拟:线上误update的恢复的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 51CTO平台老男孩教育精品视频全场5-
- 下一篇: C++ typeid操作符