MyISAM 表是保存成文件的形式,因此相對比較容易備份,上面提到的幾種方法都可以使用。Innodb 所有的表都保存在同一個數(shù)據(jù)文件 ibdata1 中(也可能是多個文件,或者是獨立的表空間文件),相對來說比較不好備份,免費的方案可以是拷貝數(shù)據(jù)文件、備份 binlog,或者用 mysqldump。1. 使用直接拷貝數(shù)據(jù)庫備份 典型的如cp、tar或cpio實用程序當你使用直接備份方法時,必須保證表不在被使用。如果服務器在你正在拷貝一個表時改變它,拷貝就失去意義。保證你的拷貝完整性的最好方法是關閉服務器,拷貝文件,然后重啟服務器。 如果你不想關閉服務器,要在執(zhí)行表檢查的同時鎖定服務器。如果服務器在運行,相同的制約也適用于拷貝文件,應該使用相同的鎖定協(xié)議讓服務器“安靜下來”。當你完成了MySQL數(shù)據(jù)庫備份時,需要重啟服務器(如果關閉了它)或釋放加在表上的鎖定(如果你讓服務器運行)。 要用直接拷貝文件把一個數(shù)據(jù)庫從一臺機器拷貝到另一臺機器上,只是將文件拷貝到另一臺服務器主機的適當數(shù)據(jù)目錄下即可。要確保文件是MyIASM格式或兩臺機器有相同的硬件結構,否則你的數(shù)據(jù)庫在另一臺主機上有奇怪的內容。你也應該保證在另一臺機器上的服務器在你正在安裝數(shù)據(jù)庫表時不訪問它們。2. 使用mysqldump數(shù)據(jù)庫備份mysqldump 是采用SQL級別的備份機制,它將數(shù)據(jù)表導成 SQL 腳本文件,在不同的 MySQL 版本之間升級時相對比較合適,這也是最常用的備份方法。mysqldump程序備份數(shù)據(jù)庫較慢,但它生成的文本文件便于移植。mysqldump 的一些主要參數(shù):1)--compatible=name它告訴 mysqldump,導出的數(shù)據(jù)將和哪種數(shù)據(jù)庫或哪個舊版本的 MySQL 服務器相兼容。值可以為 ansi、mysql323、mysql40、postgresql、oracle、mssql、db2、maxdb、no_key_options、no_tables_options、no_field_options 等,要使用幾個值,用逗號將它們隔開。當然了,它并不保證能完全兼容,而是盡量兼容。2)--complete-insert,-c導出的數(shù)據(jù)采用包含字段名的完整 INSERT 方式,也就是把所有的值都寫在一行。這么做能提高插入效率,但是可能會受到 max_allowed_packet 參數(shù)的影響而導致插入失敗。因此,需要謹慎使用該參數(shù),至少我不推薦。3)--default-character-set=charset指定導出數(shù)據(jù)時采用何種字符集,如果數(shù)據(jù)表不是采用默認的 latin1 字符集的話,那么導出時必須指定該選項,否則再次導入數(shù)據(jù)后將產(chǎn)生亂碼問題。4)--disable-keys告訴mysqldump 在 INSERT 語句的開頭和結尾增加 ; 和 ; 語句,這能大大提高插入語句的速度,因為它是在插入完所有數(shù)據(jù)后才重建索引的。該選項只適合 MyISAM 表。5)--extended-insert = true|false默認情況下,mysqldump 開啟 --complete-insert 模式,因此不想用它的的話,就使用本選項,設定它的值為 false 即可。6)--hex-blob使用十六進制格式導出二進制字符串字段。如果有二進制數(shù)據(jù)就必須使用本選項。影響到的字段類型有 BINARY、VARBINARY、BLOB。7)--lock-all-tables,-x在開始導出之前,提交請求鎖定所有數(shù)據(jù)庫中的所有表,以保證數(shù)據(jù)的一致性。這是一個全局讀鎖,并且自動關閉 --single-transaction 和 --lock-tables 選項。8)--lock-tables它和--lock-all-tables 類似,不過是鎖定當前導出的數(shù)據(jù)表,而不是一下子鎖定全部庫下的表。本選項只適用于 MyISAM 表,如果是 Innodb 表可以用 --single-transaction 選項。9)--no-create-info,-t只導出數(shù)據(jù),而不添加 CREATE TABLE 語句。10)--no-data,-d不導出任何數(shù)據(jù),只導出數(shù)據(jù)庫表結構。11)--opt這只是一個快捷選項,等同于同時添加 --add-drop-tables --add-locking --create-option --disable-keys --extended-insert --lock-tables --quick --set-charset 選項。本選項能讓 mysqldump 很快的導出數(shù)據(jù),并且導出的數(shù)據(jù)能很快導回。該選項默認開啟,但可以用 --skip-opt 禁用。注意,如果運行 mysqldump 沒有指定 --quick 或 --opt 選項,則會將整個結果集放在內存中。如果導出大數(shù)據(jù)庫的話可能會出現(xiàn)問題。12)--quick,-q該選項在導出大表時很有用,它強制 mysqldump 從服務器查詢取得記錄直接輸出而不是取得所有記錄后將它們緩存到內存中。13)--routines,-R導出存儲過程以及自定義函數(shù)。14)--single-transaction該選項在導出數(shù)據(jù)之前提交一個 BEGIN SQL語句,BEGIN 不會阻塞任何應用程序且能保證導出時數(shù)據(jù)庫的一致性狀態(tài)。它只適用于事務表,例如 InnoDB 和 BDB。 本選項和 --lock-tables 選項是互斥的,因為 LOCK TABLES 會使任何掛起的事務隱含提交。 要想導出大表的話,應結合使用 --quick 選項。--triggers同時導出觸發(fā)器。該選項默認啟用,用 --skip-triggers 禁用它。備份:使用mysqldump備份數(shù)據(jù)庫其實就是把數(shù)據(jù)庫轉儲成一系列CREATE TABLE和INSERT語句,通過這些語句我們就可重新生成數(shù)據(jù)庫。使用mysqldump的方法如下:% mysqldump --opt testdb | gzip /data/backup/testdb.bak#--opt選項會對轉儲過程進行優(yōu)化,生成的備份文件會小一點,后的管道操作會進行數(shù)據(jù)壓縮% mysqldump --opt testdb mytable1,mytable2 | gzip /data/backup/testdb_mytable.bak#可在數(shù)據(jù)庫后接數(shù)據(jù)表名,只導出指定的數(shù)據(jù)表,多個數(shù)據(jù)表可用逗號分隔--opt選項還可激活--add-drop-table選項,它將會在備份文件的每條CREATE TABLE前加上一條DROP TABLE IF EXISTS語句。這可方便進行數(shù)據(jù)表的更新,而不會發(fā)生“數(shù)據(jù)表已存在”的錯誤。用mysqldump命令還可直接把數(shù)據(jù)庫轉移到另外一臺服務器上,不用生成備份文件。重復執(zhí)行可定期更新遠程數(shù)據(jù)庫。% mysqladmin -h remote_host create testdb% mysqldump --opt testdb | mysql -h remote_host testdb另外還可通過ssh遠程調用服務器上的程序,如:% ssh remote_host mysqladmin create testdb% mysqldump --opt testdb | ssh remote_host mysql testdb 通過直接拷貝系統(tǒng)文件的方式備份數(shù)據(jù)庫,在備份時,要確保沒有人對數(shù)據(jù)庫進行修改操作。要做到這點,最好關閉服務器。如果不能關閉的,要以只讀方試鎖定有關數(shù)據(jù)表。下面是一些示例:% cp -r db /backup/db #備份db數(shù)據(jù)庫到/backup/db目錄% cp table_name.* /backup/db #只備份table_name數(shù)據(jù)表% scp -r db remotehot:/usr/local/mysql/data #用scp把數(shù)據(jù)庫直接拷貝到遠程服務器,在把數(shù)據(jù)庫直接拷貝到遠程主機時,應注意兩臺機器必須有同樣的硬件結構,或者將拷貝的數(shù)據(jù)表全部是可移植數(shù)據(jù)表類型?;蛘?usr/local/mysql/bin/mysqldump -uroot -proot \--default-character-set=utf8 --opt --extended-insert=false \--triggers -R --hex-blob -x testdb testdb.sql使用以下 SQL 來備份 Innodb 表:/usr/local/mysql/bin/mysqldump -uroot -proot \--default-character-set=utf8 --opt --extended-insert=false \--triggers -R --hex-blob --single-transaction testdb testdb.sql另外,如果想要實現(xiàn)在線備份,還可以使用 --master-data 參數(shù)來實現(xiàn),如下:/usr/local/mysql/bin/mysqldump -uroot -proot \--default-character-set=utf8 --opt --master-data=1 \--single-transaction --flush-logs testdb testdb.sql它只是在一開始的瞬間請求鎖表,然后就刷新binlog了,而后在導出的文件中加入CHANGE MASTER 語句來指定當前備份的binlog位置,如果要把這個文件恢復到slave里去,就可以采用這種方法來做。 還原:用mysqldump 備份出來的文件是一個可以直接倒入的 SQL 腳本,有兩種方法可以將數(shù)據(jù)導入。直接用 mysql 客戶端例如:/usr/local/mysql/bin/mysql -uroot -proot testdb testdb.sql用SOURCE 語法其實這不是標準的 SQL 語法,而是 mysql 客戶端提供的功能,例如:SOURCE /tmp/testdb.sql;這里需要指定文件的絕對路徑,并且必須是 mysqld 運行用戶(例如 nobody)有權限讀取的文件。 3. 使用mysqlhotcopy數(shù)據(jù)庫備份 使用mysqlhotcopy工具,它是一個Perl DBI腳本,可在不關閉服務器的情況下備份數(shù)據(jù)庫,mysqlhotcopy 是一個 PERL 程序,最初由Tim Bunce編寫。它使用 LOCK TABLES、FLUSH TABLES 和 cp 或 scp 來快速備份數(shù)據(jù)庫。它是備份數(shù)據(jù)庫或單個表的最快的途徑,但它只能運行在數(shù)據(jù)庫文件(包括數(shù)據(jù)表定義文件、數(shù)據(jù)文件、索引文件)所在的機器上。mysqlhotcopy 只能用于備份 MyISAM,并且只能運行在 類Unix 和 NetWare 系統(tǒng)上。它主要的優(yōu)點是:它直接拷貝文件,所以它比mysqldump快??勺詣油瓿蓴?shù)據(jù)鎖定工作,備份時不用關閉服務器。能刷新日志,使備份文件和日志文件的檢查點能保持同步。備份:mysqlhotcopy 支持一次性拷貝多個數(shù)據(jù)庫,同時還支持正則表達。以下是幾個例子:/usr/local/mysql/bin/mysqlhotcopy -h=localhost -u=root -p=root \testdb /tmp (把數(shù)據(jù)庫目錄 testdb 拷貝到 /tmp 下)/usr/local/mysql/bin/mysqlhotcopy -h=localhost -u=root -p=root \testdb_1 testdb_2 testdb_n /tmp/usr/local/mysql/bin/mysqlhotcopy -h=localhost -u=root -p=root \testdb./regex/ /tmp 還原:mysqlhotcopy 備份出來的是整個數(shù)據(jù)庫目錄,使用時可以直接拷貝到 mysqld 指定的 datadir (在這里是 /usr/local/mysql/data/)目錄下即可,同時要注意權限的問題,如下例:cp -rf testdb /usr/local/mysql/data/chown -R nobody:nobody /usr/local/mysql/data/ (將 testdb 目錄的屬主改成 mysqld 運行用戶) 4. 使用SQL語句數(shù)據(jù)庫備份 BACKUP TABLE 語法其實和 mysqlhotcopy 的工作原理差不多,都是鎖表,然后拷貝數(shù)據(jù)文件。它能實現(xiàn)在線備份,但是效果不理想,因此不推薦使用。它只拷貝表結構文件和數(shù)據(jù)文件,不同時拷貝索引文件,因此恢復時比較慢。備份:BACK TABLE tbl_test TO '/tmp/testdb/'; #把tbl_test數(shù)據(jù)庫備份到/tmp/testdb/目錄里,會自動創(chuàng)建一個testdb目錄 為了執(zhí)行該語句,你必須擁有那些表的FILE權限和SELECT權限,備份目錄還必須是服務器可寫的。該語句執(zhí)行時,會先把內存中的數(shù)據(jù)寫入磁盤,再把各個數(shù)據(jù)表的.frm(表結構定義文件)、.MYD(數(shù)據(jù))文件從數(shù)據(jù)目錄拷貝到備份目錄。它不拷貝.MYI(索引)文件,因為它能用另外兩個文件重建。BACKUP TABLE語句備份時,依次鎖定數(shù)據(jù)表,當同時備份多個數(shù)據(jù)表時,數(shù)據(jù)表可能會被修改,所以備份0完成時,備份文件中的數(shù)據(jù)和現(xiàn)時數(shù)據(jù)表中的數(shù)據(jù)可能會有差異,為了消除該差異,我們可用只讀方式鎖定數(shù)據(jù)表,在備份完成后再解鎖。如:mysql LOCK TABLES tb1 READ,tb2 READ;mysql BACKUP TABLE tb1,tb2 TO 'backup/db';mysql UNLOCK TABLES;使用BACKUP TABLE語句備份的數(shù)據(jù)表可用RESTORE TABLE重新加載到服務器。注意,必須要有 FILE 權限才能執(zhí)行本SQL,并且目錄 /tmp/testdb/ 必須能被 mysqld 用戶可寫,導出的文件不能覆蓋已經(jīng)存在的文件,以避免安全問題。SELECT INTO OUTFILE 則是把數(shù)據(jù)導出來成為普通的文本文件,可以自定義字段間隔的方式,方便處理這些數(shù)據(jù)。 例子:SELECT * INTO OUTFILE '/tmp/testdb/tbl_test.txt' FROM tbl_test;注意,必須要有 FILE 權限才能執(zhí)行本SQL,并且文件 /tmp/testdb/tbl_test.txt 必須能被 mysqld 用戶可寫,導出的文件不能覆蓋已經(jīng)存在的文件,以避免安全問題。還原:用BACKUP TABLE 方法備份出來的文件,可以運行 RESTORE TABLE 語句來恢復數(shù)據(jù)表。例子:RESTORE TABLE FROM '/tmp/testdb/';權限要求類似上面所述。用SELECT INTO OUTFILE 方法備份出來的文件,可以運行 LOAD DATA INFILE 語句來恢復數(shù)據(jù)表。例子:LOAD DATA INFILE '/tmp/testdb/tbl_name.txt' INTO TABLE tbl_name;權限要求類似上面所述。倒入數(shù)據(jù)之前,數(shù)據(jù)表要已經(jīng)存在才行。
我們提供的服務有:成都網(wǎng)站設計、做網(wǎng)站、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、積石山保安族東鄉(xiāng)族ssl等。為上1000家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的積石山保安族東鄉(xiāng)族網(wǎng)站制作公司
首先確認一下是否有定期的備份任務,如果沒有在考慮下面的方式。
配置參數(shù)上,是否開啟了bin-log日志?如果開啟了并且bin-log日志的周期保留比較長,可以通過重放bin-log日志的方式恢復數(shù)據(jù)。
因為磁盤空間不足,我的一個虛擬機服務器崩潰了。結果數(shù)據(jù)庫服務器進程無法啟動,數(shù)據(jù)也就無法導出。只能想辦法從數(shù)據(jù)庫原始文件 ibdata 和 frm 文件中恢復數(shù)據(jù)庫。
因為沒有經(jīng)驗,好不容易才找到了恢復方法。特此記錄,以備后用。
磁盤空間不足之后,mysqld 進程無法啟動,提示“Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)”。這真是讓人無比頭大,數(shù)據(jù)庫根本連接不上。
目錄 Contents
1. 保存原始數(shù)據(jù)庫文件
2. 恢復方法
3. 參考資料:
1. 保存原始數(shù)據(jù)庫文件?
好在數(shù)據(jù)庫原始文件還在。在我的系統(tǒng)環(huán)境和配置情況下,這些文件位于 /var/lib/mysql/ 文件夾下面。假設數(shù)據(jù)庫名是 test,則這些文件表現(xiàn)為:
--mysql
|--test
|--1.frm
|--2.frm
|...
|--mysql
|...
|--ib_logfile0
|--ib_logfile1
|--ibdata1
|...
這些就是原始數(shù)據(jù)庫文件,可以用來恢復數(shù)據(jù)庫。將這些文件額外保存一份,以防萬一。
2. 恢復方法?
我的原始虛擬機完全沒有磁盤空間而無法啟動數(shù)據(jù)庫服務器進程。雖然試著刪除一些不需要的文件,但是數(shù)據(jù)庫卻始終無法連接。于是我新建了一個幾乎一樣的虛擬機(當然磁盤加大了),試圖將這些數(shù)據(jù)庫文件導入并恢復數(shù)據(jù)庫。
在經(jīng)歷了很多錯誤之后,終于找到了正確的方法:
安裝完成新服務器之后,通過命令行新建了與原來一樣的數(shù)據(jù)庫:數(shù)據(jù)庫名稱、用戶名、密碼都一樣。如果有多個數(shù)據(jù)庫需要恢復,就都給建好。(跟配置新服務器一樣,參見安裝和配置 MYSQL 數(shù)據(jù)庫服務器。)
停止 mysqld 進程
service mysqld stop
將備份的原始數(shù)據(jù)庫文件中的所有 .frm 文件(保持原來的目錄結構)和 ibdata1 文件復制到新服務器的數(shù)據(jù)庫文件目錄中(如果新服務器操作系統(tǒng)和配置環(huán)境一樣,那么目錄結構也一樣),其它文件不要。
使用 -innodb_force_recovery=6參數(shù)啟動數(shù)據(jù)庫服務器進程,這里是
/etc/init.d/mysqld start -defaults-file=/etc/my.cnf -standalone -console -innodb_force_recovery=6
OK,數(shù)據(jù)庫恢復完成。
打開mysql的bin log功能:
對于mysql也是支持增量備份,但要打開mysql的bin log功能。
我們修改mysql的配置文件。linux是/etc/my.cnf,windows是mysql的安裝目錄/my.ini
我們在[mysqld]下面加上log-bin一行代碼,如下面。
[mysqld]
log-bin=mysql-bin
復制代碼
加完后重起mysql即可。
某客戶更新數(shù)據(jù)的時候,誤刪了數(shù)據(jù)庫的內容,因為數(shù)據(jù)庫做了主從,但是沒有做備份(備份很重要?。。┬液瞄_啟了bin-log,之后只好把整個日志的記錄拿回來本地進行恢復。
之后自己也做了一個簡單的測試,對數(shù)據(jù)進行恢復,具體如下:
1、新建一個表
CREATE TABLE `lynn`.`sn_test` ( `name` VARCHAR( 10 ) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL , `age` INT( 3 ) NOT NULL ) ENGINE = MYISAM;
2、插入多條數(shù)據(jù)
INSERT INTO `lynn`.`sn_test` (`name`, `age`) VALUES ('lynn1', '1');
INSERT INTO `lynn`.`sn_test` (`name`, `age`) VALUES ('lynn2', '2');
INSERT INTO `lynn`.`sn_test` (`name`, `age`) VALUES ('lynn3', '3');
INSERT INTO `lynn`.`sn_test` (`name`, `age`) VALUES ('lynn4', '4');
3、查看數(shù)據(jù)并刪除
mysql select * from sn_test;
+-------+-----+
| name | age |
+---------+---+
| lynn1 | 1 |
| lynn2 | 2 |
| lynn3 | 3 |
| lynn4 | 4 |
+---------+-----+
4 rows in set (0.00 sec)
mysql delete from sn_test;
Query OK, 4 rows affected (0.00 sec)
mysql select * from sn_test;
Empty set (0.00 sec)
4、mysqlbinlog恢復數(shù)據(jù)
mysqlbinlog mysql-bin.000006 1.sql
查看1.txt里面數(shù)據(jù)插入的紀錄,把刪除之前的數(shù)據(jù)進行恢復
mysqlbinlog mysql-bin.000006 --start-position=2471 --stop-position=2876 | mysql -uroot -p123
重新登錄,查看數(shù)據(jù),OK,已經(jīng)成功恢復了
對于數(shù)據(jù)庫操作,應該注意如下問題:
1、要常備份(全備,增量備份),出了問題可以最快恢復數(shù)據(jù);
2、操作數(shù)據(jù)庫前,要把需要操作的數(shù)據(jù)庫或者表dump出來;
3、需要把bin-log打開,就算沒有做上面的兩步,也可以通過日志恢復數(shù)據(jù)
1:官方百萬級別的測試數(shù)據(jù)庫:
官方測試數(shù)據(jù)庫github網(wǎng)址:
下載到目錄,解壓即可,運行命令:
2:自己創(chuàng)建簡單測試數(shù)據(jù)庫:
快速隨機生成測試語言的網(wǎng)站:
選擇sql和想生成的字段,點擊生成Generate!生成即可。
在MySQL輸入生成的語句即可。
3:測試備份還原時用到的命令
刪庫跑路測試(先備份好)
還原后查詢庫的表數(shù)據(jù)是否完整。
采用復制整個數(shù)據(jù)存放目錄
1:查看數(shù)據(jù)庫數(shù)據(jù)存放位置
有兩種方法:
1):在數(shù)據(jù)庫中用命令 show variables like 'datadir'; 查看
2):在配置文件中查看,配置了 datadir 目錄的可查看。沒有配置的默認為 /var/lib/mysql/ 位置
Linux中查看配置文件
2:復制目錄或者目錄下某個數(shù)據(jù)庫名
3:還原時直接復制文件夾到數(shù)據(jù)庫目錄即可
mysqldump又可叫做全量備份。
參數(shù) --databases 同 -B ,單獨一個庫,也可省略。
1、備份命令mysqldump格式
格式:mysqldump -h主機名 -P端口 -u用戶名 -p密碼 database 數(shù)據(jù)庫名 文件名.sql
備份testDatabase數(shù)據(jù)庫
2、備份MySQL數(shù)據(jù)庫為帶刪除表的格式
備份MySQL數(shù)據(jù)庫為帶刪除表的格式,能夠讓該備份覆蓋已有數(shù)據(jù)庫而不需要手動刪除原有數(shù)據(jù)庫。
3、直接將MySQL數(shù)據(jù)庫壓縮備份
備份并壓縮
4、備份MySQL數(shù)據(jù)庫某個(些)表
備份testDatabase中的myTable表,不需要用參數(shù) --databases 或者 -B
5、同時備份多個MySQL數(shù)據(jù)庫
同時備份testDatabase和 employees兩個庫
6、備份服務器上所有數(shù)據(jù)庫
參數(shù) --all-databases 同 -A
7、還原MySQL數(shù)據(jù)庫的命令
1) 不指定數(shù)據(jù)名還原,默認生成原數(shù)據(jù)庫名稱,還原所有數(shù)據(jù)庫。
2) 指定數(shù)據(jù)名還原,還原指定單個數(shù)據(jù)庫,需在數(shù)據(jù)庫種預先創(chuàng)建一個testDatabase名稱。
3) 還原壓縮的MySQL數(shù)據(jù)庫
4) 進入數(shù)據(jù)庫用source導入
增量備份是針對于數(shù)據(jù)庫的bin-log日志進行備份的,增量備份是在全量的基礎上進行操作的。增量備份主要是靠mysql記錄的bin-log日志。
1:查看是否開啟bin-log日志
進入mysql輸入命令可查看。
顯示如下為開啟狀態(tài),日志文件在/var/lib/mysql/以binlog.00001的格式保存。
如未開啟,需要在配置文件種配置
2:查看目前使用的bin-log日志文件
進入mysql查看命令。
顯示如下,目前使用的是binlog.000022文件,所有操作都記錄在此文件。
查看當前testDatabase的表myTable數(shù)據(jù)如下,
3:刷新日志,使用新的日志文件(備份)
在命令端執(zhí)行命令
日志文件從 binlog.000022 變?yōu)?binlog.000023
這時相當與已經(jīng)備份成功,備份文件即為上次的binlog.000022日志文件。
4:刪除數(shù)量,從日志還原數(shù)據(jù)
1) 刪除ABC行
查詢以及沒有ABC行列。
2) 恢復數(shù)據(jù)ABC行
退出mysql,在命令端用mysqlbinlog命令恢復到binlog.000022日志狀態(tài)。
進入數(shù)據(jù)庫再次查看數(shù)據(jù),ABC已經(jīng)恢復。
增量備份完成。
如果你要恢復的數(shù)據(jù)庫是包含授權表的mysql數(shù)據(jù)庫,您將需要使用--skip贈款-tables選項來運行服務器恢復整個數(shù)據(jù)庫
- 首先,。否則,服務器會抱怨不能找到授權表?;謴捅砗?,執(zhí)行mysqladmin沖水privileges告訴服務器裝載授權表,并用它們來啟動。數(shù)據(jù)庫目錄到其他地方的原始內容
復制。例如,您可以使用它們在以后的事后分析檢查表(驗尸)的崩潰。
酒店與最新的數(shù)據(jù)庫備份文件重新加載。如果您打算使用mysqldump的所加載的文件,則需要輸入它們作為mysql的。如果您打算使用從數(shù)據(jù)庫文件直接拷貝(例如,使用tar或CP),它會復制他們直接回數(shù)據(jù)庫目錄中。然而,在這種情況下,你應該在關閉之前,該服務器復制這些文件,然后重新啟動它。在備份過程中
重做日志,然后查詢更新數(shù)據(jù)庫表中。對于所有可用的更新日志,你可以使用它作為mysql的輸入。指定--one-database選項,因此MySQL只是要還原的數(shù)據(jù)庫執(zhí)行查詢。如果你意識到有必要使用所有的更新日志文件,可以使用包含以下命令日志的目錄:
%LS-TRL更新(0-9)* | xargs的貓| mysql--。一個數(shù)據(jù)庫DB_NAME
ls命令生成一個單獨的日志文件更新列表,更新日志文件根據(jù)服務器(你知道,如果你其中的任何文件,排序順序生成的順序進行排序會發(fā)生變化,這將導致在更新日志中以錯誤的順序使用)。有限公司您可能需要使用一些更新日志。例如,如果日志,因為命名update.392備份,pdate.393等產(chǎn)生的,可以在命令重新運行它們:
%的mysql - 一個數(shù)據(jù)庫DB_NAME 錄入。 392
%的mysql - 一個數(shù)據(jù)庫DB_NAME updata.393 ...
如果您正在運行的恢復,并打算使用更新日志恢復由于失誤降數(shù)據(jù)的基礎上,DROPTABLE或DELETE語句和丟失的信息時,一定要在開始更新日志刪除這些語句。
恢復單個表
恢復單個表是非常困難的。如果是的mysqldump備份文件生成的,它只是不包含數(shù)據(jù),您需要一個表,你需要提取的相關線路,并利用它們作為mysql的輸入,這部分比較容易。困難的是,提取在該表的更新日志中使用的片段。你會發(fā)現(xiàn):mysql_find_rows工具在這方面有所幫助,它可以提取多行從更新日志查詢。另一種可能性是使用另一臺服務器
恢復整個數(shù)據(jù)庫,然后將該文件復制到表的原始數(shù)據(jù)庫。這其實很容易!當文件被復制回數(shù)據(jù)庫目錄,確保原始數(shù)據(jù)庫服務器關閉。