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

首頁 > 數據庫 > MySQL > 正文

關于mysql數據庫誤刪除后的數據恢復操作說明

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

在日常運維工作中,對于mysql數據庫的備份是至關重要的!數據庫對于網站的重要性使得我們對mysql數據的管理不容有失!
然后,是人總難免會犯錯誤,說不定哪天大腦短路了來個誤操作把數據庫給刪除了,怎么辦???

下面,就mysql數據庫誤刪除后的恢復方案進行說明。

一、工作場景

(1)MySQL數據庫每晚12:00自動完全備份。
(2)某天早上上班,9點的時候,一同事犯暈drop了一個數據庫!
(3)需要緊急恢復!可利用備份的數據文件以及增量的binlog文件進行數據恢復。

二、數據恢復思路

(1)利用全備的sql文件中記錄的CHANGE MASTER語句,binlog文件及其位置點信息,找出binlog文件中增量的那部分。
(2)用mysqlbinlog命令將上述的binlog文件導出為sql文件,并剔除其中的drop語句
(3)通過全備文件和增量binlog文件的導出sql文件,就可以恢復到完整的數據。

三、實例說明

----------------------------------------
首先,要確保mysql開啟了binlog日志功能
在/etc/my.cnf文件里的[mysqld]區塊添加:
log-bin=mysql-bin
然后重啟mysql服務
----------------------------------------

(1)在ops庫下創建一張表customers

mysql> use ops;mysql> create table customers(-> id int not null auto_increment,-> name char(20) not null,-> age int not null,-> primary key(id)-> )engine=InnoDB;Query OK, 0 rows affected (0.09 sec)mysql> show tables;+---------------+| Tables_in_ops |+---------------+| customers |+---------------+1 row in set (0.00 sec)mysql> desc customers;+-------+----------+------+-----+---------+----------------+| Field | Type | Null | Key | Default | Extra |+-------+----------+------+-----+---------+----------------+| id | int(11) | NO | PRI | NULL | auto_increment || name | char(20) | NO | | NULL | || age | int(11) | NO | | NULL | |+-------+----------+------+-----+---------+----------------+3 rows in set (0.02 sec)mysql> insert into customers values(1,"wangbo","24");Query OK, 1 row affected (0.06 sec)mysql> insert into customers values(2,"guohui","22");Query OK, 1 row affected (0.06 sec)mysql> insert into customers values(3,"zhangheng","27");Query OK, 1 row affected (0.09 sec)mysql> select * from customers;+----+-----------+-----+| id | name | age |+----+-----------+-----+| 1 | wangbo | 24 || 2 | guohui | 22 || 3 | zhangheng | 27 |+----+-----------+-----+3 rows in set (0.00 sec)

(2)現在進行全備份

[root@vm-002 ~]# mysqldump -uroot -p -B -F -R -x --master-data=2 ops|gzip >/opt/backup/ops_$(date +%F).sql.gz
Enter password:
[root@vm-002 ~]# ls /opt/backup/
ops_2016-09-25.sql.gz

-----------------

參數說明:

-B:指定數據庫
-F:刷新日志
-R:備份存儲過程等
-x:鎖表
--master-data:在備份語句里添加CHANGE MASTER語句以及binlog文件及位置點信息
-----------------

(3)再次插入數據

mysql> insert into customers values(4,"liupeng","21");Query OK, 1 row affected (0.06 sec)mysql> insert into customers values(5,"xiaoda","31");Query OK, 1 row affected (0.07 sec)mysql> insert into customers values(6,"fuaiai","26");Query OK, 1 row affected (0.06 sec)mysql> select * from customers;+----+-----------+-----+| id | name | age |+----+-----------+-----+| 1 | wangbo | 24 || 2 | guohui | 22 || 3 | zhangheng | 27 || 4 | liupeng | 21 || 5 | xiaoda | 31 || 6 | fuaiai | 26 |+----+-----------+-----+6 rows in set (0.00 sec)

(4)此時誤操作,刪除了test數據庫

mysql> drop database ops;
Query OK, 1 row affected (0.04 sec)

此時,全備之后到誤操作時刻之間,用戶寫入的數據在binlog中,需要恢復出來!

(5) 查看全備之后新增的binlog文件

[root@vm-002 ~]# cd /opt/backup/[root@vm-002 backup]# lsops_2016-09-25.sql.gz[root@vm-002 backup]# gzip -d ops_2016-09-25.sql.gz [root@vm-002 backup]# lsops_2016-09-25.sql[root@vm-002 backup]# grep CHANGE ops_2016-09-25.sql -- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000002', MASTER_LOG_POS=106;

這是全備時刻的binlog文件位置
即mysql-bin.000002的106行,因此在該文件之前的binlog文件中的數據都已經包含在這個全備的sql文件中了

(6)移動binlog文件,并導出為sql文件,剔除其中的drop語句

查看mysql的數據存放目錄,有下面可知是在/var/lib/mysql下

[root@vm-002 backup]# ps -ef|grep mysqlroot 9272 1 0 01:43 pts/1 00:00:00 /bin/sh /usr/bin/mysqld_safe --datadir=/var/lib/mysql --socket=/var/lib/mysql/mysql.sock --pid-file=/var/run/mysqld/mysqld.pid --basedir=/usr --user=mysqlmysql 9377 9272 0 01:43 pts/1 00:00:00 /usr/libexec/mysqld --basedir=/usr --datadir=/var/lib/mysql --user=mysql --log-error=/var/log/mysqld.log --pid-file=/var/run/mysqld/mysqld.pid --socket=/var/lib/mysql/mysql.sock[root@vm-002 backup]# cd /var/lib/mysql/[root@vm-002 mysql]# lsibdata1 ib_logfile0 ib_logfile1 mysql mysql-bin.000001 mysql-bin.000002 mysql-bin.index mysql.sock test[root@vm-002 mysql]# cp mysql-bin.000002 /opt/backup/

將binlog文件導出sql文件,并vim編輯它刪除其中的drop語句

[root@vm-002 backup]# mysqlbinlog -d ops mysql-bin.000002 >002bin.sql[root@vm-002 backup]# ls002bin.sql mysql-bin.000002 ops_2016-09-25.sql[root@vm-002 backup]# vim 002bin.sql #刪除里面的drop語句

注意:

在恢復全備數據之前必須將該binlog文件移出,否則恢復過程中,會繼續寫入語句到binlog,最終導致增量恢復數據部分變得比較混亂

(7)恢復數據

[root@vm-002 backup]# mysql -uroot -p < ops_2016-09-25.sql
Enter password:
[root@vm-002 backup]#

查看數據庫,看看ops庫在不在

mysql> show databases;+--------------------+| Database |+--------------------+| information_schema || mysql || ops || test |+--------------------+4 rows in set (0.00 sec)mysql> use ops;Reading table information for completion of table and column namesYou can turn off this feature to get a quicker startup with -ADatabase changedmysql> select * from customers;+----+-----------+-----+| id | name | age |+----+-----------+-----+| 1 | wangbo | 0 || 2 | guohui | 0 || 3 | zhangheng | 0 |+----+-----------+-----+3 rows in set (0.00 sec)

此時恢復了全備時刻的數據

接著,使用002bin.sql文件恢復全備時刻到刪除數據庫之間,新增的數據

[root@vm-002 backup]# mysql -uroot -p ops <002bin.sql
Enter password:
[root@vm-002 backup]#

再次查看數據庫,發現全備份到刪除數據庫之間的那部分數據也恢復了!!

mysql> select * from customers;+----+-----------+-----+| id | name | age |+----+-----------+-----+| 1 | wangbo | 24 || 2 | guohui | 22 || 3 | zhangheng | 27 || 4 | liupeng | 21 || 5 | xiaoda | 31 || 6 | fuaiai | 26 |+----+-----------+-----+6 rows in set (0.00 sec)

以上就是mysql數據庫增量數據恢復的實例過程!

**********************************************

最后,總結幾點:

1)本案例適用于人為SQL語句造成的誤操作或者沒有主從復制等的熱備情況宕機時的修復

2)恢復條件為mysql要開啟binlog日志功能,并且要全備和增量的所有數據

3)恢復時建議對外停止更新,即禁止更新數據庫

4)先恢復全量,然后把全備時刻點以后的增量日志,按順序恢復成SQL文件,然后把文件中有問題的SQL語句刪除(也可通過時間和位置點),再恢復到數據庫。

以上這篇關于mysql數據庫誤刪除后的數據恢復操作說明就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品自产拍在线观看中文| 国内免费久久久久久久久久久| 久久躁日日躁aaaaxxxx| 国产成人精品一区| 亚洲欧美国产va在线影院| 日韩高清欧美高清| 欧美人与性动交a欧美精品| 亚洲香蕉伊综合在人在线视看| 日韩电影免费观看在线观看| 国产欧美日韩免费看aⅴ视频| 国产欧美在线视频| 亚洲美女性生活视频| 国产亚洲免费的视频看| 日韩av在线免费播放| 中文字幕亚洲欧美日韩2019| 欧美国产日韩视频| 欧洲日韩成人av| 久久精品中文字幕| 九九热这里只有精品6| 国模吧一区二区| 国内外成人免费激情在线视频网站| 日韩在线观看高清| 国产精品高清在线| 久久精品99久久久久久久久| 日本最新高清不卡中文字幕| 日韩有码片在线观看| 久久精品人人爽| 欧美交受高潮1| 国产精品成人一区二区| 国产成+人+综合+亚洲欧美丁香花| 91成人性视频| 欧美黄色片免费观看| 91精品啪aⅴ在线观看国产| 日韩精品在线视频美女| 九九精品视频在线| 青青久久av北条麻妃海外网| 北条麻妃久久精品| 热99精品里视频精品| 一区二区国产精品视频| 国产精品久久久久久久久久东京| 全球成人中文在线| 国产日韩在线视频| 久久成人国产精品| 国产亚洲精品久久久久久777| 欧美一区深夜视频| 精品久久久一区二区| 91国偷自产一区二区三区的观看方式| 亚洲视频在线视频| 韩国三级电影久久久久久| 国产日产欧美a一级在线| 国产午夜精品视频| 欧美人成在线视频| 欧美成人性色生活仑片| 在线观看欧美日韩国产| 久久综合电影一区| 国产精品白嫩初高中害羞小美女| 91精品久久久久久久久久入口| 成人免费看片视频| 亚洲国产精彩中文乱码av在线播放| 日本精品久久久久久久| xxx成人少妇69| 欧美日韩一区二区免费在线观看| 蜜臀久久99精品久久久久久宅男| 精品日韩美女的视频高清| 中文字幕免费精品一区| 国产精品视频久久久久| 亚洲iv一区二区三区| 18性欧美xxxⅹ性满足| 国产在线拍偷自揄拍精品| 91精品视频专区| 欧美成人一区二区三区电影| 伊人久久久久久久久久久| 久久精品国产91精品亚洲| 欧美视频在线免费| 亚洲男人天堂网| 欧美性理论片在线观看片免费| 色悠悠久久88| 国产精品高潮粉嫩av| 欧美电影免费观看高清| 亚洲一二三在线| 久久亚洲国产精品成人av秋霞| 黑人巨大精品欧美一区免费视频| 亚洲精品自拍偷拍| 中文字幕精品—区二区| 精品国产区一区二区三区在线观看| 精品二区三区线观看| 亚洲欧美在线磁力| 亚洲美女在线观看| 97视频免费在线观看| 中文亚洲视频在线| 日韩av123| 亚洲已满18点击进入在线看片| 日本高清久久天堂| 91精品国产色综合久久不卡98口| 亚洲精品自拍第一页| 国产精品专区第二| 欧美精品videosex牲欧美| 国产精品永久免费在线| www国产亚洲精品久久网站| 亚洲xxx自由成熟| 欧美激情一级精品国产| 亚洲国产精品成人va在线观看| 日韩中文字幕视频| 日韩精品在线免费| 亚洲一区二区日本| 美女久久久久久久| 色悠久久久久综合先锋影音下载| 久久久久日韩精品久久久男男| 亚洲乱码国产乱码精品精| 国产精品av在线| 亚洲毛片在线免费观看| 亚洲天堂av网| 韩国精品久久久999| 日韩国产精品视频| 亚洲毛片在线免费观看| 日韩在线观看av| 91影视免费在线观看| 中文字幕在线亚洲| 国产亚洲精品美女久久久久| 中文字幕久久亚洲| 国产a级全部精品| 国产精品自拍视频| 国产91成人在在线播放| 尤物精品国产第一福利三区| 欧美一级电影在线| 亚洲最大福利网站| 国产香蕉97碰碰久久人人| 一区二区三区四区精品| 国产成人精品一区二区三区| 欧美黄色三级网站| 久久久国产精品免费| 欧美日韩国产精品专区| 国产精品一区二区久久久久| 亚洲一区二区三区乱码aⅴ| 91在线直播亚洲| 国产精品成人一区二区三区吃奶| 亚洲欧美日韩第一区| 91极品女神在线| 精品久久中文字幕| 亚洲区一区二区| 欧美日韩国产综合新一区| 伊人伊成久久人综合网小说| 国产精品高潮呻吟久久av无限| 欧美最顶级的aⅴ艳星| 91社区国产高清| 亚洲精品91美女久久久久久久| 黑人巨大精品欧美一区二区三区| 欧美xxxx14xxxxx性爽| 精品免费在线观看| 97视频在线观看播放| 97久久久免费福利网址| 亚洲精品在线看| 欧美精品久久久久久久| 91高清免费视频| 日韩美女视频在线观看| 欧美亚洲成人xxx| 中文字幕日韩有码| 亚洲美女免费精品视频在线观看| 亚洲社区在线观看| 欧洲一区二区视频| 亚洲一级免费视频| 国产精品一区二区三区久久久| 亚洲午夜精品久久久久久性色| 久久久久久亚洲精品不卡|