国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

MySQL數據庫誤操作后快速回滾的方式

2024-07-24 12:34:52
字體:
來源:轉載
供稿:網友
  binlog2sql快速回滾
  開源工具binlog2sql:
 
  首先,確認你的MySQL server開啟了binlog,設置了以下參數:(binlog + row模式)
  [mysqld]
  server-id = 1
  log_bin = /var/log/mysql/mysql-bin.log
  max_binlog_size = 1000M
  binlog-format = row
 
  如果沒有開啟binlog,也沒有預先生成回滾SQL,那真的無法快速回滾了。對存放重要業務數據的MySQL,強烈建議開啟binlog。
 
  隨后,安裝開源工具binlog2sql。binlog2sql是一款簡單易用的binlog解析工具,其中一個功能就是生成回滾SQL。
 
  git clone https://github.com/danfengcao/binlog2sql.git
  pip install -r requirements.txt
 
 
  回滾步驟:
 
  登錄mysql,查看目前的binlog文件
  mysql> show master logs;
  +------------------+-----------+
  | Log_name     | File_size |
  +------------------+-----------+
  | mysql-bin.000001 | 12262268 |
  | mysql-bin.000002 |  132776 |
  +------------------+-----------+
 
  最新的binlog文件是mysql-bin.000002,我們再定位誤操作SQL的binlog位置
  $ python binlog2sql/binlog2sql.py -h227.0.0.1 -P3306 -uadmin -p'admin' -dtest -t f --start-file='mysql-bin.000002'
  輸出:
  DELETE FROM `test`.`f` WHERE `did`=18 AND `updateTime`='2016-12-06 12:28:18' AND `uid`=1 LIMIT 1; #start 4 end 314
  DELETE FROM `test`.`f` WHERE `did`=19 AND `updateTime`='2016-12-06 12:55:56' AND `uid`=2 LIMIT 1; #start 4 end 314
  DELETE FROM `test`.`f` WHERE `did`=20 AND `updateTime`='2016-12-07 14:00:58' AND `uid`=3 LIMIT 1; #start 4 end 314
  DELETE FROM `test`.`f` WHERE `did`=21 AND `updateTime`='2016-12-07 14:01:00' AND `uid`=4 LIMIT 1; #start 4 end 314
 
  生成回滾sql,并檢查回滾sql是否正確
  $ python binlog2sql/binlog2sql.py -h227.0.0.1 -P3306 -uadmin -p'admin' -dtest -t f --start-file='mysql-bin.000002' --start-pos=4 --end-pos=314 -B
  輸出:
  INSERT INTO `test`.`f`(`did`, `updateTime`, `uid`) VALUES (21, '2016-12-07 14:01:00', 4); #start 4 end 314
  INSERT INTO `test`.`f`(`did`, `updateTime`, `uid`) VALUES (20, '2016-12-07 14:00:58', 3); #start 4 end 314
  INSERT INTO `test`.`f`(`did`, `updateTime`, `uid`) VALUES (19, '2016-12-06 12:55:56', 2); #start 4 end 314
  INSERT INTO `test`.`f`(`did`, `updateTime`, `uid`) VALUES (18, '2016-12-06 12:28:18', 1); #start 4 end 314
 
  確認回滾sql正確,執行回滾語句。登錄mysql,數據回滾成功。
  $ python binlog2sql.py -h227.0.0.1 -P3306 -uadmin -p'admin' -dtest -t f --start-file='mysql-bin.000002' --start-pos=4 --end-pos=314 -B | mysql -h227.0.0.1 -P3306 -uadmin -p'admin'
  mysql> select * from f;
  +-----+-----+---------------------+
  | uid | did | updateTime     |
  +-----+-----+---------------------+
  |  1 | 18 | 2016-12-06 12:28:18 |
  |  2 | 19 | 2016-12-06 12:55:56 |
  |  3 | 20 | 2016-12-07 14:00:58 |
  |  4 | 21 | 2016-12-07 14:01:00 |
  +-----+-----+---------------------+
 
  常見問題
  1.有人會問,我DDL誤操作了怎么快速回滾?比如drop了一張大表。
  很難做到,因為即使在在row模式下,DDL操作也不會把每行數據的變化記錄到binlog,所以DDL無法通過binlog回滾。實現DDL回滾,必須要在執行DDL前先備份老數據。確實有人通過修改mysql server源碼實現了DDL的快速回滾,我找到阿里的xiaobin lin提交了一個patch。但據我所知,國內很少有互聯網公司應用了這個特性。原因的話,我認為最主要還是懶的去折騰,沒必要搞這個低頻功能,次要原因是會增加一些額外存儲。
 
 
  2.mysql除了binlog2sql,是否還有其他回滾工具?
  當然有。阿里彭立勛對mysqlbinlog增加了flashback的特性,這應該是mysql最早有的flashback功能,彭解決的是DML的回滾,并說明了利用binlog進行DML閃回的設計思路。DDL回滾特性也是由阿里團隊提出并實現的。這兩個功能是有創新精神的,此后出現的閃回工具基本都是對上面兩者的模仿。另外,去哪兒開源的Inception是一套MySQL自動化運維工具,這個就比較重了,支持DML回滾,還不是從binlog回滾的,是從備份回滾的,也支持DDL回滾表結構,數據是回滾不了滴~

(編輯:武林網)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 尚志市| 抚顺县| 宁武县| 五原县| 呼伦贝尔市| 姜堰市| 临洮县| 淳化县| 翼城县| 平邑县| 武定县| 长宁县| 五寨县| 南郑县| 盐池县| 新兴县| 嘉兴市| 贞丰县| 临沭县| 安宁市| 长春市| 黑水县| 凤翔县| 社会| 陈巴尔虎旗| 长葛市| 黑水县| 绥宁县| 北海市| 茶陵县| 尉氏县| 滁州市| 溧阳市| 台东县| 泾源县| 鄂温| 镇康县| 英德市| 大竹县| 秭归县| 南皮县|