婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Mysql誤操作后利用binlog2sql快速回滾的方法詳解

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

熱門標簽:ps制作地圖標注gif 成都優派外呼系統 寧波企業外呼系統收費 上海智能外呼系統代理商 電子地圖標注電話 聊城智能外呼系統運營商 扎樣申請400電話 地圖標注人員兼職 沈陽電銷外呼系統原理是什么

前言

在日常工作或者學習中,操作數據庫時候難免會因為“大意”而誤操作,需要快速恢復的話通過備份來恢復是不太可能的,下面這篇文章主要給大家介紹關于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.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需要的最小權限集合:

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 id20;  # 刪除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: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

# 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: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連接配置

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

解析模式

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

解析范圍控制

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

對象過濾

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

3.4、開始回滾

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

3.5、登陸數據庫驗證

四、注意事項

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

server_id = 1
log_bin = /data/mysql/mysql-bin.log
max_binlog_size = 1G
binlog_format = row
binlog_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閃回數據。

總結

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

您可能感興趣的文章:
  • mysql閃回工具binlog2sql安裝配置教程詳解
  • mysql8.0.20配合binlog2sql的配置和簡單備份恢復的步驟詳解

標簽:林芝 汕頭 咸寧 內江 宿州 AXB 三明 朔州

巨人網絡通訊聲明:本文標題《Mysql誤操作后利用binlog2sql快速回滾的方法詳解》,本文關鍵詞  Mysql,誤,操作,后,利用,binlog2sql,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Mysql誤操作后利用binlog2sql快速回滾的方法詳解》相關的同類信息!
  • 本頁收集關于Mysql誤操作后利用binlog2sql快速回滾的方法詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲精品第一国产综合野| jvid福利写真一区二区三区| 欧美午夜影院一区| 五月天亚洲精品| 精品久久久久av影院 | 91精品国产91久久综合桃花 | 国产日产欧产精品推荐色| 国产成人精品aa毛片| 国产精品久久久久精k8| 日本韩国欧美在线| 无吗不卡中文字幕| 久久久亚洲精品一区二区三区 | 天天av天天翘天天综合网色鬼国产| 色美美综合视频| 日韩电影在线看| 国产欧美一区视频| 一本高清dvd不卡在线观看| 五月婷婷另类国产| 久久亚洲一区二区三区明星换脸| 韩国av一区二区| 亚洲三级电影网站| 日韩一区二区三区视频在线观看| 成人一二三区视频| 首页亚洲欧美制服丝腿| 欧美国产一区二区在线观看 | 日韩欧美激情四射| 99re成人精品视频| 美日韩一区二区三区| 国产精品成人免费| 欧美一区二区三区日韩视频| 成人av小说网| 久久er精品视频| 亚洲免费高清视频在线| 久久亚洲一级片| 欧美人与禽zozo性伦| 盗摄精品av一区二区三区| 日本亚洲天堂网| 亚洲精品成人a在线观看| 久久综合久久综合久久| 欧美精品一卡两卡| 日本精品视频一区二区| 国产不卡免费视频| 日本成人在线看| 亚洲一区二区视频在线观看| 久久久久久久综合色一本| 91精品国模一区二区三区| 99精品久久久久久| 国产成人亚洲精品青草天美| 热久久久久久久| 一卡二卡三卡日韩欧美| 亚洲欧洲日产国码二区| 久久看人人爽人人| 欧美成人三级电影在线| 欧美美女直播网站| 色综合天天综合在线视频| 成人性色生活片免费看爆迷你毛片| 肉色丝袜一区二区| 亚洲aaa精品| 亚洲一二三专区| 亚洲视频一二区| 136国产福利精品导航| 日本一区二区视频在线| 久久综合色婷婷| 久久久精品免费免费| 日韩免费高清av| 欧美mv和日韩mv国产网站| 日韩欧美国产精品| 日韩一级高清毛片| 精品免费一区二区三区| 日韩欧美一区二区免费| 日韩免费高清电影| 欧美精品一区在线观看| 久久综合999| 久久久精品2019中文字幕之3| 亚洲精品一区二区三区香蕉| 久久亚洲免费视频| 久久久www成人免费毛片麻豆 | 欧美一级欧美一级在线播放| 在线电影一区二区三区| 欧美大肚乱孕交hd孕妇| 亚洲精品一区二区三区在线观看| 久久婷婷国产综合国色天香 | 亚洲精品网站在线观看| 亚洲综合一区在线| 婷婷六月综合网| 看电视剧不卡顿的网站| 国产一区二区美女诱惑| 成人的网站免费观看| 色狠狠一区二区| 91精品国产综合久久婷婷香蕉 | 国产一区二区精品久久91| 激情综合五月婷婷| 东方欧美亚洲色图在线| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 国产精品美女久久久久久久久| 中文字幕一区二区三区蜜月| 亚洲资源中文字幕| 美国毛片一区二区三区| 国产成人高清视频| 欧美色老头old∨ideo| 日韩精品一区二区三区蜜臀 | 欧美人牲a欧美精品| 亚洲精品在线三区| 亚洲精品日韩综合观看成人91| 亚洲成人av在线电影| 精品亚洲欧美一区| 97精品久久久久中文字幕| 欧美久久久久中文字幕| 久久综合久久综合亚洲| 一区二区在线看| 男女视频一区二区| 色综合久久精品| 欧美精品一区二区在线播放| 亚洲视频一区二区免费在线观看| 日本欧美韩国一区三区| 成人午夜又粗又硬又大| 欧美日韩精品高清| 国产欧美视频一区二区三区| 亚洲精品国久久99热| 久久疯狂做爰流白浆xx| 色综合久久九月婷婷色综合| 日韩三级伦理片妻子的秘密按摩| 中文乱码免费一区二区| 亚洲电影一级黄| 国产99精品国产| 欧美一区二区啪啪| 一区二区三区四区精品在线视频| 国产在线视频精品一区| 欧美午夜影院一区| 国产精品久久久久久久久免费相片| 日本伊人午夜精品| 一本一道综合狠狠老| 日本一二三四高清不卡| 久久精品99国产精品| 欧美日韩你懂得| 国产精品白丝在线| 国产精品69久久久久水密桃| 91精品婷婷国产综合久久性色| 亚洲美女偷拍久久| 成人性生交大合| 久久久久久久免费视频了| 日韩成人免费电影| 欧美视频一区二区在线观看| 亚洲婷婷国产精品电影人久久| 国产一区二区免费视频| 日韩免费福利电影在线观看| 偷拍日韩校园综合在线| 欧美色成人综合| 一区二区三区四区在线播放 | 欧美精彩视频一区二区三区| 麻豆中文一区二区| 91精品国产欧美一区二区成人| 亚洲午夜一二三区视频| 在线观看国产一区二区| 亚洲精品乱码久久久久久| 9色porny自拍视频一区二区| 中文字幕欧美激情一区| 国产一区二区看久久| 国产日韩一级二级三级| 国产精品一品二品| 国产三级一区二区三区| 国产成人亚洲综合a∨婷婷图片| 久久精品一二三| 高清beeg欧美| 亚洲欧美一区二区不卡| 99精品偷自拍| 亚洲综合区在线| 3atv一区二区三区| 麻豆精品一区二区av白丝在线| 日韩一区二区高清| 国产一区二区三区最好精华液| www激情久久| 波多野结衣中文一区| 亚洲精选在线视频| 欧美三级一区二区| 免费黄网站欧美| 国产午夜精品一区二区| 大白屁股一区二区视频| 亚洲欧美日韩国产中文在线| 欧美网站一区二区| 青青草国产精品97视觉盛宴| 精品国产乱码久久久久久老虎 | 欧洲国产伦久久久久久久| 亚洲激情综合网| 欧美一区二区三区影视| 国产激情偷乱视频一区二区三区| 国产精品久久久久久久久图文区| 91免费观看国产| 强制捆绑调教一区二区| 精品免费国产二区三区| 99久久久久久| 婷婷激情综合网| 欧美激情综合网| 欧美精品久久99| 成人97人人超碰人人99| 亚洲午夜影视影院在线观看| 精品精品国产高清a毛片牛牛| www.在线欧美| 午夜视频在线观看一区二区三区 | 在线电影院国产精品|