老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業(yè)提供網(wǎng)站建設(shè)、域名注冊、服務(wù)器等服務(wù)

MySQL使用mysqldump+binlog完整恢復(fù)被刪除的數(shù)據(jù)庫的方法

這篇文章主要講解了MySQL使用mysqldump+binlog完整恢復(fù)被刪除的數(shù)據(jù)庫的方法,內(nèi)容清晰明了,對此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會有幫助。

10年積累的網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)經(jīng)驗(yàn),可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先做網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有高州免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。

(一)概述

在日常MySQL數(shù)據(jù)庫運(yùn)維過程中,可能會遇到用戶誤刪除數(shù)據(jù),常見的誤刪除數(shù)據(jù)操作有:

  • 用戶執(zhí)行delete,因?yàn)闂l件不對,刪除了不應(yīng)該刪除的數(shù)據(jù)(DML操作);
  • 用戶執(zhí)行update,因?yàn)闂l件不對,更新數(shù)據(jù)出錯(cuò)(DML操作);
  • 用戶誤刪除表drop table(DDL操作);
  • 用戶誤清空表truncate(DDL操作);
  • 用戶刪除數(shù)據(jù)庫drop database,跑路(DDL操作)
  • …等

這些情況雖然不會經(jīng)常遇到,但是遇到了,我們需要有能力將其恢復(fù),下面講述如何恢復(fù)。

(二)恢復(fù)原理

如果要將數(shù)據(jù)庫恢復(fù)到故障點(diǎn)之前,那么需要有數(shù)據(jù)庫全備和全備之后產(chǎn)生的所有二進(jìn)制日志。

全備作用 :使用全備將數(shù)據(jù)庫恢復(fù)到上一次完整備份的位置;

二進(jìn)制日志作用:利用全備的備份集將數(shù)據(jù)庫恢復(fù)到上一次完整備份的位置之后,需要對上一次全備之后數(shù)據(jù)庫產(chǎn)生的所有動作進(jìn)行重做,而重做的過程就是解析二進(jìn)制日志文件為SQL語句,然后放到數(shù)據(jù)庫里面再次執(zhí)行。

舉個(gè)例子:小明在4月1日晚上8:00使用了mysqldump對數(shù)據(jù)庫進(jìn)行了備份,在4月2日早上12:00的時(shí)候,小華不小心刪除了數(shù)據(jù)庫,那么,在執(zhí)行數(shù)據(jù)庫恢復(fù)的時(shí)候,需要使用4月1日晚上的完整備份將數(shù)據(jù)庫恢復(fù)到“4月1日晚上8:00”,那4月1日晚上8:00以后到4月2日早上12:00之前的數(shù)據(jù)如何恢復(fù)呢?就得通過解析二進(jìn)制日志來對這段時(shí)間執(zhí)行過的SQL進(jìn)行重做。

(三)刪庫恢復(fù)測試

(3.1)實(shí)驗(yàn)?zāi)康?/p>

在本次實(shí)驗(yàn)中,我直接測試刪庫,執(zhí)行drop database lijiamandb,確認(rèn)是否可以恢復(fù)。

(3.2)測試過程

在測試數(shù)據(jù)庫lijiamandb中創(chuàng)建測試表test01和test02,然后執(zhí)行mysqldump對數(shù)據(jù)庫進(jìn)行全備,之后執(zhí)行drop database,確認(rèn)database是否可以恢復(fù)。

STEP1:創(chuàng)建測試數(shù)據(jù),為了模擬日常繁忙的生產(chǎn)環(huán)境,頻繁的操作數(shù)據(jù)庫產(chǎn)生大量二進(jìn)制日志,我特地使用存儲過程和EVENT產(chǎn)生大量數(shù)據(jù)。

創(chuàng)建測試表:

use lijiamandb;create table test01
 (
 id1 int not null auto_increment,
 name varchar(30),
 primary key(id1)
 );

create table test02
 (
 id2 int not null auto_increment,
 name varchar(30),
 primary key(id2)
 );

創(chuàng)建存儲過程,往測試表里面插入數(shù)據(jù),每次執(zhí)行該存儲過程,往test01和test02各自插入10000條數(shù)據(jù):

CREATE DEFINER=`root`@`%` PROCEDURE `p_insert`()
BEGIN
#Routine body goes here...
DECLARE str1 varchar(30);
DECLARE str2 varchar(30);
DECLARE i int;
set i = 0;

while i < 10000 do
 set str1 = substring(md5(rand()),1,25);
 insert into test01(name) values(str1);
 set str2 = substring(md5(rand()),1,25);
 insert into test02(name) values(str1);
 set i = i + 1;
 end while;
 END

制定事件,每隔10秒鐘,執(zhí)行上面的存儲過程:

use lijiamandb;
 create event if not exists e_insert
 on schedule every 10 second
 on completion preserve
 do call p_insert();

啟動EVENT,每個(gè)10s自動向test01和test02各自插入10000條數(shù)據(jù)

mysql> show variables like '%event_scheduler%';
+----------------------------------------------------------+-------+
| Variable_name | Value |
+----------------------------------------------------------+-------+
| event_scheduler | OFF |
+----------------------------------------------------------+-------+

mysql> set global event_scheduler = on;
 Query OK, 0 rows affected (0.08 sec)

--過3分鐘。。。
STEP2:第一步生成大量測試數(shù)據(jù)后,使用mysqldump對lijiamandb數(shù)據(jù)庫執(zhí)行完全備份
mysqldump -h292.168.10.11 -uroot -p123456 -P3306 --single-transaction --master-data=2 --events --routines --databases lijiamandb > /mysql/backup/lijiamandb.sql

注意:必須要添加--master-data=2,這樣才會備份集里面mysqldump備份的終點(diǎn)位置。

--過3分鐘。。。

STEP3:為了便于數(shù)據(jù)庫刪除前與刪除后數(shù)據(jù)一致性校驗(yàn),先停止表的數(shù)據(jù)插入,此時(shí)test01和test02都有930000行數(shù)據(jù),我們后續(xù)恢復(fù)也要保證有930000行數(shù)據(jù)。

mysql> set global event_scheduler = off;
Query OK, 0 rows affected (0.00 sec)

mysql> select count(*) from test01;
 +----------+
 | count(*) |
 +----------+
 | 930000 |
 +----------+
row in set (0.14 sec)

mysql> select count(*) from test02;
 +----------+
 | count(*) |
 +----------+
 | 930000 |
 +----------+
row in set (0.13 sec)

STEP4:刪除數(shù)據(jù)庫

mysql> drop database lijiamandb;
Query OK, 2 rows affected (0.07 sec)

STEP5:使用mysqldump的全備導(dǎo)入

mysql> create database lijiamandb;
Query OK, 1 row affected (0.01 sec)

mysql> exit
 Bye
 [root@masterdb binlog]# mysql -uroot -p123456 lijiamandb < /mysql/backup/lijiamandb.sql 
 mysql: [Warning] Using a password on the command line interface can be insecure.

在執(zhí)行全量備份恢復(fù)之后,發(fā)現(xiàn)只有753238筆數(shù)據(jù):

[root@masterdb binlog]# mysql -uroot -p123456 lijiamandb 

mysql> select count(*) from test01;
 +----------+
 | count(*) |
 +----------+
 | 753238 |
 +----------+
row in set (0.12 sec)

mysql> select count(*) from test02;
 +----------+
 | count(*) |
 +----------+
 | 753238 |
 +----------+
row in set (0.11 sec)

很明顯,全量導(dǎo)入之后,數(shù)據(jù)不完整,接下來使用mysqlbinlog對二進(jìn)制日志執(zhí)行增量恢復(fù)。

使用mysqlbinlog進(jìn)行增量日志恢復(fù)最重要的就是確定待恢復(fù)的起始位置(start-position)和終止位置(stop-position),起始位置(start-position)是我們執(zhí)行全被之后的位置,而終止位置則是故障發(fā)生之前的位置。
STEP6:確認(rèn)mysqldump備份到的最終位置

[root@masterdb backup]# cat lijiamandb.sql |grep "CHANGE MASTER"
-- CHANGE MASTER TO MASTER_LOG_FILE='master-bin.000044', MASTER_LOG_POS=8526828

備份到了44號日志的8526828位置,那么恢復(fù)的起點(diǎn)可以設(shè)置為:44號日志的8526828。

--接下來確認(rèn)要恢復(fù)的終點(diǎn)位置,即執(zhí)行"DROP DATABASE LIJIAMAN"之前的位置,需要到binlog里面確認(rèn)。

[root@masterdb binlog]# ls
 master-bin.000001 master-bin.000010 master-bin.000019 master-bin.000028 master-bin.000037 master-bin.000046 master-bin.000055
 master-bin.000002 master-bin.000011 master-bin.000020 master-bin.000029 master-bin.000038 master-bin.000047 master-bin.000056
 master-bin.000003 master-bin.000012 master-bin.000021 master-bin.000030 master-bin.000039 master-bin.000048 master-bin.000057
 master-bin.000004 master-bin.000013 master-bin.000022 master-bin.000031 master-bin.000040 master-bin.000049 master-bin.000058
 master-bin.000005 master-bin.000014 master-bin.000023 master-bin.000032 master-bin.000041 master-bin.000050 master-bin.000059
 master-bin.000006 master-bin.000015 master-bin.000024 master-bin.000033 master-bin.000042 master-bin.000051 master-bin.index
 master-bin.000007 master-bin.000016 master-bin.000025 master-bin.000034 master-bin.000043 master-bin.000052
 master-bin.000008 master-bin.000017 master-bin.000026 master-bin.000035 master-bin.000044 master-bin.000053
 master-bin.000009 master-bin.000018 master-bin.000027 master-bin.000036 master-bin.000045 master-bin.000054

# 多次查找,發(fā)現(xiàn)drop database在54號日志文件
[root@masterdb binlog]# mysqlbinlog -v master-bin.000056 | grep -i "drop database lijiamandb"
 [root@masterdb binlog]# mysqlbinlog -v master-bin.000055 | grep -i "drop database lijiamandb"
 [root@masterdb binlog]# mysqlbinlog -v master-bin.000055 | grep -i "drop database lijiamandb"
 [root@masterdb binlog]# mysqlbinlog -v master-bin.000054 | grep -i "drop database lijiamandb"
drop database lijiamandb

# 保存到文本,便于搜索
[root@masterdb binlog]# mysqlbinlog -v master-bin.000054 > master-bin.txt


# 確認(rèn)drop database之前的位置為:54號文件的9019487
 # at 9019422
 #200423 16:07:46 server id 11 end_log_pos 9019487 CRC32 0x86f13148 Anonymous_GTID last_committed=30266 sequence_number=30267 rbr_only=no
 SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/;
 # at 9019487
 #200423 16:07:46 server id 11 end_log_pos 9019597 CRC32 0xbd6ea5dd Query thread_id=100 exec_time=0 error_code=0
 SET TIMESTAMP=1587629266/*!*/;
 SET @@session.sql_auto_is_null=0/*!*/;
 /*!\C utf8 *//*!*/;
 SET @@session.character_set_client=33,@@session.collation_connection=33,@@session.collation_server=33/*!*/;
 drop database lijiamandb
 /*!*/;
 # at 9019597
 #200423 16:09:25 server id 11 end_log_pos 9019662 CRC32 0x8f7b11dc Anonymous_GTID last_committed=30267 sequence_number=30268 rbr_only=no
SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/;
 # at 9019662
 #200423 16:09:25 server id 11 end_log_pos 9019774 CRC32 0x9b42423d Query thread_id=100 exec_time=0 error_code=0
 SET TIMESTAMP=1587629365/*!*/;
 create database lijiamandb

STEP7:確定了開始結(jié)束點(diǎn),執(zhí)行增量恢復(fù)
開始:44號日志的8526828
結(jié)束:54號文件的9019487

這里分為3條命令執(zhí)行,起始日志文件涉及到參數(shù)start-position參數(shù),單獨(dú)執(zhí)行;中止文件涉及到stop-position參數(shù),單獨(dú)執(zhí)行;中間的日志文件不涉及到特殊參數(shù),全部一起執(zhí)行。

# 起始日志文件

# 起始日志文件
mysqlbinlog --start-position=8526828 /mysql/binlog/master-bin.000044 | mysql -uroot -p123456

 
# 中間日志文件
mysqlbinlog /mysql/binlog/master-bin.000045 /mysql/binlog/master-bin.000046 /mysql/binlog/master-bin.000047 /mysql/binlog/master-bin.000048 /mysql/binlog/master-bin.000049 /mysql/binlog/master-bin.000050 /mysql/binlog/master-bin.000051 /mysql/binlog/master-bin.000052 /mysql/binlog/master-bin.000053 | mysql -uroot -p123456

 
# 終止日志文件

mysqlbinlog --stop-position=9019487 /mysql/binlog/master-bin.000054 | mysql -uroot -p123456

STEP8:恢復(fù)結(jié)束,確認(rèn)全部數(shù)據(jù)已經(jīng)還原

[root@masterdb binlog]# mysql -uroot -p123456 lijiamandb
mysql> select count(*) from test01;
+----------+
| count(*) |
+----------+
| 930000 |
+----------+
row in set (0.15 sec)

mysql> select count(*) from test02;
+----------+
 | count(*) |
+----------+
 | 930000 |
+----------+
row in set (0.13 sec)

(四)總結(jié)

1.對于DML操作,binlog記錄了所有的DML數(shù)據(jù)變化:
--對于insert,binlog記錄了insert的行數(shù)據(jù)
--對于update,binlog記錄了改變前的行數(shù)據(jù)和改變后的行數(shù)據(jù)
--對于delete,binlog記錄了刪除前的數(shù)據(jù)
假如用戶不小心誤執(zhí)行了DML操作,可以使用mysqlbinlog將數(shù)據(jù)庫恢復(fù)到故障點(diǎn)之前。

2.對于DDL操作,binlog只記錄用戶行為,而不記錄行變化,但是并不影響我們將數(shù)據(jù)庫恢復(fù)到故障點(diǎn)之前。

總之,使用mysqldump全備加binlog日志,可以將數(shù)據(jù)恢復(fù)到故障前的任意時(shí)刻。

看完上述內(nèi)容,是不是對MySQL使用mysqldump+binlog完整恢復(fù)被刪除的數(shù)據(jù)庫的方法有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


本文題目:MySQL使用mysqldump+binlog完整恢復(fù)被刪除的數(shù)據(jù)庫的方法
網(wǎng)站鏈接:http://www.xueling.net.cn/article/gpojji.html

其他資訊

在線咨詢
服務(wù)熱線
服務(wù)熱線:028-86922220
TOP
主站蜘蛛池模板: 日本少妇被爽到高潮动态图 | 亚洲国产精品无码成人片久久 | 91在线中字| 亚洲呦女专区 | 成人av视频在线观看 | 一区二区在线免费观看视频 | 久久男女视频 | 激情不卡一区二区三区视频在线 | 老司机午夜在线视频 | 未发育成型小奶头毛片av | 亚州一区二区三区 | 波多野结衣强奷系列在线观看 | 少妇性色午夜淫片aaaze | 国产精品国产三级国产普通 | 97伦理 | 成人av一区二区亚洲精 | 欧美成人天天综合在线视色 | 国产精品精品久久久久久 | 夜夜躁狠狠躁 | 精品美女一区二区 | 511yc影院免费理论片 | 国产成人无码免费视频麻豆 | 大陆一级黄色片 | 国产精品一区二区在线观看网站 | 国产又粗又猛又爽又黄的视频软件 | 绯色av中文字幕一区二区 | 久久九九免费视频 | 韩国免费A级作爱片无码 | 国内91视频| 国产亚洲AV片在线观看16女人 | 亚洲风情在线观看 | 国产精品按摩 | 香蕉高清永久在线视频 | 国产高清无码在线一区二区 | 激情黄页| 在线观看91视频 | 深夜男人你懂的六月婷婷天堂 | 在线不卡a资源高清 | 国产一区二区三区亚洲 | 69av片| 中国一级簧色带免费看 |