亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

Mysql誤操作后利用binlog2sql快速回滾的方法詳解

2024-07-24 13:13:56
字體:
來源:轉載
供稿:網友

前言

在日常工作或者學習中,操作數據庫時候難免會因為“大意”而誤操作,需要快速恢復的話通過備份來恢復是不太可能的,下面這篇文章主要給大家介紹關于Mysql誤操作后利用binlog2sql快速回滾的方法,話不多說,來一起看看詳細的介紹:

一、總體解釋:

DML(data manipulation language):

       它們是SELECT、UPDATE、INSERT、DELETE,就象它的名字一樣,這4條命令是用來對數據庫里的數據進行操作的語言

DDL(data definition language):

       DDL比DML要多,主要的命令有CREATE、ALTER、DROP等,DDL主要是用在定義或改變表(TABLE)的結構,數據類型,表之間的鏈接和約束等初始化工作上,他們大多在建立表時使用

DCL(Data Control Language):

       是數據庫控制功能。是用來設置或更改數據庫用戶或角色權限的語句,包括(grant,deny,revoke等)語句。在默認狀態下,只有sysadmin,dbcreator,db_owner或db_securityadmin等人員才有權力執行DCL

二、binlog2sql安裝

從mysql binlog解析出你要的sql。根據不同選項,你可以得到原始sql、回滾sql、去除主鍵的insert sql等。

2.1、用途

  • ?數據快速回滾(閃回)
  • ?主從切換后數據不一致的修復
  • ?從binlog生成標準SQL,帶來的衍生功能

2.2、安裝

# cd /usr/local# git clone https://github.com/danfengcao/binlog2sql.git# ls binlog2sql games java lib64 mariadb sbin src # cd binlog2sql# pip install -r requirements.txt-bash: pip: command not found -------------安裝pip工具-------------# wget https://bootstrap.pypa.io/get-pip.py # python get-pip.py# pip -V  #查看pip版本pip 9.0.1 from /usr/lib/python2.7/site-packages (python 2.7)# pip install -r requirements.txtRequirement already satisfied: PyMySQL==0.7.8 in /usr/lib/python2.7/site-packages (from -r requirements.txt (line 1))Requirement already satisfied: wheel==0.24.0 in /usr/lib/python2.7/site-packages (from -r requirements.txt (line 2))Requirement already satisfied: mysql-replication==0.9 in /usr/lib/python2.7/site-packages (from -r requirements.txt (line 3))

2.3、user需要的最小權限集合:

select, super/replication client, replication slave權限建議授權

mysql > GRANT SELECT,REPLICATION SLAVE,REPLICATION CLIENT ON *.* to flashback@'localhost' identified by 'flashback';mysql > GRANT SELECT,REPLICATION SLAVE,REPLICATION CLIENT ON *.* to flashback@'127.0.0.1' identified by 'flashback';

2.4、基本用法

解析出標準SQL

shell> python binlog2sql.py -h127.0.0.1 -P3306 -uadmin -p'admin' -ddatabase -t table1 table2 --start-file='mysql-bin.000002' --start-datetime='2017-01-12 18:00:00' --stop-datetime='2017-01-12 18:30:00' --start-pos=1240

解析出回滾SQL

shell> python binlog2sql.py --flashback -h127.0.0.1 -P3306 -uadmin -p'admin' -dtest -ttest3 --start-file='mysql-bin.000002' --start-position=763 --stop-position=1147

三、測試:

3.1、新建表users

create table cope_users like info_users; # 新建表insert into cope_users select * from info_users limit 500; # 插入500行數據delete from cope_users where id<20;  # 刪除20行數據

3.2、解析標準sql

# python /usr/local/binlog2sql/binlog2sql/binlog2sql.py -uflashback -pflashback -dttt -tusers --start-file='mysql-bin.000034' --start-datetime='2017-07-11 15:10:00' --stop-datetime='2017-07-11 15:12:00'DELETE FROM `ttt`.`users` WHERE `uid`='0e8e2609c748bbb052d7' AND `ip`='172.16.208.32' AND `sex`=0 AND `app_ver`='5.2.3' AND `device_type`=2 AND `guides`='' AND `last_login_time`=1481602129 AND `id`=1 AND `latitude`='' AND `add_time`=1481602080 AND `recharge_time`=0 AND `token_change_time`=1481602129 AND `expire_time`=0 AND `nickname`='阿超' AND `device_id`='cc0e154d9b5dd703eccc7d8a0dbc0f67d64b79e8' AND `push_key`='' AND `level`=0 AND `mobile`='18810895535' AND `settings`='' AND `longitude`='' AND `signature`='' AND `os_ver`='' LIMIT 1; #start 79078 end 83053 time 2017-07-11 15:11:50DELETE FROM `ttt`.`users` WHERE `uid`='b5cfbdb4205b56703a97' AND `ip`='172.16.208.48' AND `sex`=0 AND `app_ver`='5.2.2' AND `device_type`=2 AND `guides`='' AND `last_login_time`=1481602096 AND `id`=2 AND `latitude`='' AND `add_time`=1481602096 AND `recharge_time`=0 AND `token_change_time`=1481602096 AND `expire_time`=0 AND `nickname`='家長091410' AND `device_id`='fedea666076a7906be53523acc7a8b32811354fe' AND `push_key`='7759d6772c9851a2bfc13835a3d7e7da' AND `level`=0 AND `mobile`='13629470521' AND `settings`='' AND `longitude`='' AND `signature`='' AND `os_ver`='' LIMIT 1; #start 79078 end 83053 time 2017-07-11 15:11:50

3.3、解析出回滾SQL

# python /usr/local/binlog2sql/binlog2sql/binlog2sql.py --flashback -h127.0.0.1 -P3306 -uflashback -pflashback -dttt -tusers --start-file='mysql-bin.000034' --start-position=79078 --stop-position=83053

查看解析出的sql,如無誤,可打印到sql文件中/data/backup/rollback.sql

# python /usr/local/binlog2sql/binlog2sql/binlog2sql.py --flashback -uflashback -pflashback -dttt -tusers --start-file='mysql-bin.000034' --start-position=79078 --stop-position=83053> /data/backup/rollback.sql# cat /data/backup/rollback.sql `id`, `latitude`, `add_time`, `recharge_time`, `token_change_time`, `expire_time`, `nickname`, `device_id`, `push_key`, `level`, `mobile`, `settings`, `longitude`, `signature`, `os_ver`) VALUES ('24667530f4b16a446b3e', '172.16.218.75', 0, '5.2.93', 3, '{/"2103/":1,/"2100/":1,/"2101/":1,/"2102/":1,/"2104/":1,/"2105/":1}', 1490239125, 19, '', 1481610680, 0, 1490239125, 0, 'zf', 'da75b093-bd22-48f6-bbb1-d3296e29e9b5', 'be05183f80a96e788e0b0a99d1275392', 0, '15101538925', '', '', '', ''); #start 79078 end 83053 time 2017-07-11 15:11:50INSERT INTO `ttt`.`users`(`uid`, `ip`, `sex`, `app_ver`, `device_type`, `guides`, `last_login_time`, `id`, `latitude`, `add_time`, `recharge_time`, `token_change_time`, `expire_time`, `nickname`, `device_id`, `push_key`, `level`, `mobile`, `settings`, `longitude`, `signature`, `os_ver`) VALUES ('77e50b4910a9389057ed', '172.16.218.37', 0, '5.2.1.14', 3, '', 1488787835, 18, '39.978212', 1481610517, 0, 1488787835, 0, '陳俊宇', 'ed0a273d-74de-4173-92c6-55d92597bc79', '', 0, '18612482272', '', '116.306826', '', ''); #start 79078 end 83053 time 2017-07-11 15:11:50

mysql連接配置

 -h host; -P port; -u user; -p password

解析模式

  •   --realtime 持續同步binlog??蛇x。不加則同步至執行命令時最新的binlog位置。
  •   --popPk 對INSERT語句去除主鍵??蛇x。
  •   -B, --flashback 生成回滾語句??蛇x。與realtime或popPk不能同時添加。

解析范圍控制

  •   --start-file 起始解析文件。必須。
  •   --start-pos start-file的起始解析位置??蛇x。默認為start-file的起始位置;
  •   --end-file 末尾解析文件。可選。默認為start-file同一個文件。若解析模式為realtime,此選項失效。
  •   --end-pos end-file的末尾解析位置??蛇x。默認為end-file的最末位置;若解析模式為realtime,此選項失效。

對象過濾

  •    -d, --databases 只輸出目標db的sql??蛇x。默認為空。
  •    -t, --tables 只輸出目標tables的sql??蛇x。默認為空。

3.4、開始回滾

# mysql -uroot -p000000 < /data/backup/rollback.sql

3.5、登陸數據庫驗證

四、注意事項

4.1、在配置文件中設置了以下參數:

server_id = 1log_bin = /data/mysql/mysql-bin.logmax_binlog_size = 1Gbinlog_format = rowbinlog_row_image = full # 默認

4.2、在閃回的時候必須啟動 MySQL 服務

因為它是通過 BINLOG_DUMP 協議來獲取 binlog 內容,需要讀取server端 information_schema.COLUMNS 表,來獲取表結構的元信息,才能拼接成 SQL 語句。因此需要給用戶提供的最小權限如下:

GRANT SELECT, REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'user'@'%';

源碼中,主要是使用 python-mysql-replication 作為實時解析 MySQL binlog 來獲取各個 EVENT。 python-mysql-replication 實現了 MySQL 復制協議,客戶端偽裝成 slave 來獲取主的 binlog 和 EVENT。

4.3、insert、update、delete大部分時候可以解析出來標準sql和回滾sql

一種情況例外:insert、updete、delete操作之后,drop/truncate table。 此時雖然在binlog中記錄了所有的event,但是使用binlog2sql生成標準sql、回滾sql的時候已經找不到了dml操作的相應的表

4.4、DDL無法使用binlog2sql閃回數據。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品久久久久久久久久久久| 日韩美女毛茸茸| 亚洲成人免费网站| 欧美大秀在线观看| 久久久久久久久久久av| 亚洲国产91色在线| 欧美日韩国产精品| 日韩欧美成人区| 国产成人福利夜色影视| 亚洲欧美中文日韩在线| 日韩精品一区二区视频| 久久这里只有精品视频首页| 欧美日韩成人精品| 色狠狠av一区二区三区香蕉蜜桃| 亚洲性视频网站| 国产成人精品日本亚洲专区61| 国产亚洲精品va在线观看| 国产日韩在线免费| 色综合天天狠天天透天天伊人| 日韩精品中文字幕在线| 日本久久久久久久| 久久久久久国产三级电影| 在线观看精品国产视频| 91在线|亚洲| 日韩精品久久久久| 欧美精品手机在线| 久久久久久久国产| 日韩人在线观看| 一区二区三区久久精品| 成人免费视频在线观看超级碰| 中文字幕欧美日韩va免费视频| 亚洲第一视频在线观看| 久久6精品影院| 国产69精品久久久久久| 欧美成aaa人片在线观看蜜臀| 久久精品中文字幕电影| 成人做爰www免费看视频网站| 自拍偷拍亚洲在线| 97精品国产97久久久久久春色| 国产aⅴ夜夜欢一区二区三区| 国产欧美精品xxxx另类| 色综久久综合桃花网| 色琪琪综合男人的天堂aⅴ视频| 日韩大胆人体377p| 色老头一区二区三区| 91精品国产91久久久久久不卡| 懂色aⅴ精品一区二区三区蜜月| 欧美国产视频日韩| 国产精品极品美女粉嫩高清在线| 97色在线视频观看| 国产精品69av| 亚洲欧洲国产一区| 国产精品丝袜久久久久久不卡| 国产精品女视频| 国产成人av网址| 激情成人在线视频| 欧美日韩国产丝袜另类| 91精品国产综合久久久久久久久| 日韩国产欧美精品在线| 国产精品视频免费观看www| 国产日本欧美一区二区三区在线| 久久99精品久久久久久噜噜| 欧美日本中文字幕| 亚洲最新av在线网站| 成人97在线观看视频| 爽爽爽爽爽爽爽成人免费观看| 亚洲a在线播放| 不卡av在线播放| 91精品国产成人www| 精品亚洲永久免费精品| 国产不卡av在线| 国产精品高潮粉嫩av| 成人免费大片黄在线播放| 色妞色视频一区二区三区四区| 成人精品aaaa网站| 精品日韩中文字幕| 亚洲在线www| 色噜噜狠狠色综合网图区| 久久精品国产综合| 亚洲人成毛片在线播放| 性视频1819p久久| 亚洲欧美日韩精品久久| 91久久精品视频| 国语自产精品视频在线看一大j8| 久久999免费视频| 亚洲国产欧美一区二区三区久久| 久久精品中文字幕免费mv| 色悠悠久久88| 777午夜精品福利在线观看| 亚洲精品国产精品久久清纯直播| 一区二区三区无码高清视频| 欧美激情精品久久久久久| 欧美日韩免费在线| 亚洲精品一区二区久| 97在线视频观看| 欧美中文字幕在线观看| 亚洲奶大毛多的老太婆| 国产成人精品日本亚洲| 久久久久久噜噜噜久久久精品| 麻豆乱码国产一区二区三区| 欧美乱大交xxxxx| 亚洲第一男人天堂| 欧美精品日韩三级| 中文字幕九色91在线| 亚洲国产另类久久精品| 欧洲成人免费视频| 高清一区二区三区日本久| 日韩精品福利在线| 69影院欧美专区视频| 亚洲经典中文字幕| 欧美成人精品影院| 亚洲精品不卡在线| 美女扒开尿口让男人操亚洲视频网站| 亚洲成av人片在线观看香蕉| 日韩中文字幕亚洲| 在线色欧美三级视频| 精品欧美aⅴ在线网站| 国产激情综合五月久久| 国产精品一区二区三区免费视频| 国产亚洲成av人片在线观看桃| 欧美性猛交xxxx富婆| 亚洲精品日韩在线| 日韩黄色在线免费观看| 亚洲国产另类 国产精品国产免费| 正在播放国产一区| 日韩高清人体午夜| 亚洲va欧美va国产综合久久| 欧美成人一区在线| 欧美视频中文字幕在线| 亚洲国产成人精品电影| 国产精品久久久久久av| 亚洲最大成人在线| 国产精品久久久久久久久久小说| 一本大道香蕉久在线播放29| 日韩av大片免费看| 在线成人中文字幕| 欧美综合一区第一页| 成人观看高清在线观看免费| 亚洲自拍高清视频网站| 日韩美女在线看| 91热福利电影| 91中文字幕在线观看| 国模精品一区二区三区色天香| 欧洲成人在线观看| 日本高清视频一区| 国产午夜精品理论片a级探花| 久久久亚洲成人| 中文字幕一区二区三区电影| 日韩一区av在线| 精品偷拍一区二区三区在线看| 日韩国产在线播放| 亚洲人精选亚洲人成在线| 尤物九九久久国产精品的特点| 在线观看免费高清视频97| 精品久久久久久久久久久| 亚洲自拍小视频| 九九九热精品免费视频观看网站| 91久久久久久久一区二区| 国产欧美久久一区二区| 精品人伦一区二区三区蜜桃免费| 久久久久久久久久av| 91成品人片a无限观看| 欧美电影在线观看网站| 日韩精品在线观看视频|