《MYSQL數(shù)據(jù)庫Mysql誤操作后利用binlog2sql快速回滾的方法詳解》要點(diǎn):
本文介紹了MYSQL數(shù)據(jù)庫Mysql誤操作后利用binlog2sql快速回滾的方法詳解,希望對您有用。如果有疑問,可以聯(lián)系我們。
前言MYSQL數(shù)據(jù)庫
在日常工作或者學(xué)習(xí)中,操作數(shù)據(jù)庫時候難免會因?yàn)椤按笠狻倍`操作,需要快速恢復(fù)的話通過備份來恢復(fù)是不太可能的,下面這篇文章主要給大家介紹關(guān)于Mysql誤操作后利用binlog2sql快速回滾的方法,話不多說,來一起看看詳細(xì)的介紹:MYSQL數(shù)據(jù)庫
一、總體解釋:
MYSQL數(shù)據(jù)庫
DML(data manipulation language):
MYSQL數(shù)據(jù)庫
?????? 它們是SELECT、UPDATE、INSERT、DELETE,就象它的名字一樣,這4條命令是用來對數(shù)據(jù)庫里的數(shù)據(jù)進(jìn)行操作的語言
MYSQL數(shù)據(jù)庫
DDL(data definition language):
MYSQL數(shù)據(jù)庫
?????? DDL比DML要多,主要的命令有CREATE、ALTER、DROP等,DDL主要是用在定義或改變表(TABLE)的結(jié)構(gòu),數(shù)據(jù)類型,表之間的鏈接和約束等初始化工作上,他們大多在建立表時使用
MYSQL數(shù)據(jù)庫
DCL(Data Control Language):
MYSQL數(shù)據(jù)庫
?????? 是數(shù)據(jù)庫控制功能.是用來設(shè)置或更改數(shù)據(jù)庫用戶或角色權(quán)限的語句,包括(grant,deny,revoke等)語句.在默認(rèn)狀態(tài)下,只有sysadmin,dbcreator,db_owner或db_securityadmin等人員才有權(quán)力執(zhí)行DCLMYSQL數(shù)據(jù)庫
二、binlog2sql安裝
MYSQL數(shù)據(jù)庫
從mysql binlog解析出你要的sql.根據(jù)不同選項(xiàng),你可以得到原始sql、回滾sql、去除主鍵的insert sql等.MYSQL數(shù)據(jù)庫
2.1、用途
MYSQL數(shù)據(jù)庫
2.2、安裝
MYSQL數(shù)據(jù)庫
# 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.txt Requirement 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需要的最小權(quán)限集合:
MYSQL數(shù)據(jù)庫
select, super/replication client, replication slave權(quán)限建議授權(quán)MYSQL數(shù)據(jù)庫
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、基本用法
MYSQL數(shù)據(jù)庫
解析出標(biāo)準(zhǔn)SQLMYSQL數(shù)據(jù)庫
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
解析出回滾SQLMYSQL數(shù)據(jù)庫
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
三、測試:
MYSQL數(shù)據(jù)庫
3.1、新建表users
MYSQL數(shù)據(jù)庫
create table cope_users like info_users; # 新建表 insert into cope_users select * from info_users limit 500; # 插入500行數(shù)據(jù) delete from cope_users where id<20; # 刪除20行數(shù)據(jù)
3.2、解析標(biāo)準(zhǔn)sql
MYSQL數(shù)據(jù)庫
# 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:50 DELETE 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
MYSQL數(shù)據(jù)庫
# 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
MYSQL數(shù)據(jù)庫
# 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:50 INSERT 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連接配置
MYSQL數(shù)據(jù)庫
-h host; -P port; -u user; -p password
解析模式
MYSQL數(shù)據(jù)庫
解析范圍控制
MYSQL數(shù)據(jù)庫
對象過濾
MYSQL數(shù)據(jù)庫
3.4、開始回滾
MYSQL數(shù)據(jù)庫
# mysql -uroot -p000000 < /data/backup/rollback.sql
3.5、登陸數(shù)據(jù)庫驗(yàn)證
MYSQL數(shù)據(jù)庫
四、注意事項(xiàng)
MYSQL數(shù)據(jù)庫
4.1、在配置文件中設(shè)置了以下參數(shù):
MYSQL數(shù)據(jù)庫
server_id = 1 log_bin = /data/mysql/mysql-bin.log max_binlog_size = 1G binlog_format = row binlog_row_image = full # 默認(rèn)
4.2、在閃回的時候必須啟動 MySQL 服務(wù)
MYSQL數(shù)據(jù)庫
因?yàn)樗峭ㄟ^ BINLOG_DUMP 協(xié)議來獲取 binlog 內(nèi)容,需要讀取server端 information_schema.COLUMNS 表,來獲取表結(jié)構(gòu)的元信息,才能拼接成 SQL 語句.因此需要給用戶提供的最小權(quán)限如下:MYSQL數(shù)據(jù)庫
GRANT SELECT, REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'user'@'%';
源碼中,主要是使用 python-mysql-replication 作為實(shí)時解析 MySQL binlog 來獲取各個 EVENT. python-mysql-replication 實(shí)現(xiàn)了 MySQL 復(fù)制協(xié)議,客戶端偽裝成 slave 來獲取主的 binlog 和 EVENT.MYSQL數(shù)據(jù)庫
4.3、insert、update、delete大部分時候可以解析出來標(biāo)準(zhǔn)sql和回滾sql
MYSQL數(shù)據(jù)庫
一種情況例外:insert、updete、delete操作之后,drop/truncate table. 此時雖然在binlog中記錄了所有的event,但是使用binlog2sql生成標(biāo)準(zhǔn)sql、回滾sql的時候已經(jīng)找不到了dml操作的相應(yīng)的表MYSQL數(shù)據(jù)庫
4.4、DDL無法使用binlog2sql閃回?cái)?shù)據(jù).MYSQL數(shù)據(jù)庫
總結(jié)MYSQL數(shù)據(jù)庫
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對維易PHP的支持.
MYSQL數(shù)據(jù)庫
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/4841.html