mysql innobackupex增量備份恢復
mysql innobackupex 的備份:
全備:
[root@L112 backup]# innobackupex --defaults-file=/etc/my.cnf --no-timestamp --user=root --password=123456 --socket=/var/lib/mysql/mysql.sock /backup/mysqldump/full/back_26-05-2017
增量備份1
(以上次的全備為基礎),備份子目錄在back_26-05-2017下面
[root@L112 backup]#innobackupex --defaults-file=/etc/my.cnf --no-timestamp --user=root --password=123456 --socket=/var/lib/mysql/mysql.sock --incremental /backup/mysqldump/incremental/back_26-05-2017
--incremental-basedir=/backup/mysqldump/full/back_26-05-2017
增量備份2
(以上一次的增量備份back_26-05-2017為基礎),備份子目錄在back_27-05-2017下面:
[root@L112 backup]#innobackupex --defaults-file=/etc/my.cnf --no-timestamp --user=root --password=123456 --socket=/var/lib/mysql/mysql.sock --incremental /backup/mysqldump/incremental/back_27-05-2017
--incremental-basedir=/backup/mysqldump/incremental/back_26-05-2017
檢視備份的結果:
全備:
[root@L112 full]# ll
total 0
drwxr-xr-x. 6 root root 188 May 26 16:33 back_26-05-2017
增量備份兩個:
[root@L112 incremental]# ll
total 0
drwxr-xr-x. 6 root root 214 May 26 09:42 back_26-05-2017
drwxr-xr-x. 6 root root 214 May 27 15:27 back_27-05-2017
下面模擬資料丟失的情況:
刪除liuwenhe庫
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| liuwenhe |
| mysql |
| performance_schema |
| test |
+--------------------+
5 rows in set (0.00 sec)
mysql> drop database liuwenhe;
Query OK, 2 rows affected (0.05 sec)
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| test |
+--------------------+
4 rows in set (0.00 sec)
如上所示,liuwenhe庫已經被刪除掉了。
下面展示具體恢復的過程。。。。。。。。
恢復:
整個過程分為三步驟,整體上可以理解為:先把增量備份的資料倒進全備份中,然後最後使用全備份恢復即可,
第一步:是在所有備份目錄下重做已提交的日誌,注意最後一個增量備份是沒有--redo-only的,並且資料最後是在全備份中,如:
innobackupex --apply-log --redo-only BASE-DIR
innobackupex --apply-log --redo-only BASE-DIR --incremental-dir=INCREMENTAL-DIR-1
innobackupex --apply-log BASE-DIR --incremental-dir=INCREMENTAL-DIR-2
或者
加上使用者名稱和密碼,以及使用的配置檔案:
innobackupex --defaults-file=/opt/mysql/my.cnf --user=root --password=*** --apply-log --redo-only BASE-DIR
innobackupex --defaults-file=/opt/mysql/my.cnf --user=root --password=*** --apply-log --redo-only BASE-DIR --incremental-dir=INCREMENTAL-DIR-1
innobackupex --defaults-file=/opt/mysql/my.cnf --user=root --password=*** --apply-log BASE-DIR --incremental-dir=INCREMENTAL-DIR-2
其中BASE-DIR是指全備目錄,INCREMENTAL-DIR-1是指第一次的增量備份,INCREMENTAL-DIR-2是指第二次的增量備份,以此類推。這裡要注意的是:最後一步的增量備份並沒有--redo-only選項!還有,可以使用--use_memory提高效能。
以上語句執行成功之後,最終資料在BASE-DIR(即全備目錄)下。
我的具體操作:
[root@L112 full]# innobackupex --apply-log --redo-only /backup/mysqldump/full/back_26-05-2017
[root@L112 full]# innobackupex --apply-log --redo-only /backup/mysqldump/full/back_26-05-2017/--incremental-dir=/backup/mysqldump/incremental/back_26-05-2017/
[root@L112 full]# innobackupex --apply-log /backup/mysqldump/full/back_26-05-2017/ --incremental-dir=/backup/mysqldump/incremental/back_27-05-2017/
第二步:回滾未完成的日誌,也就是已經重新整理到磁碟的,但是還沒有提交的。
innobackupex --apply-log BASE-DIR
我的具體操作:
[root@L112 full]# innobackupex --apply-log /backup/mysqldump/full/back_26-05-2017/
上面執行完之後,BASE-DIR裡的備份檔案已完全準備就緒,
最後一步:是複製,這個步驟需要注意先把資料庫關掉,並且把資料檔案和日誌檔案刪除:
innobackupex --copy-back BASE-DIR
我的具體操作是:
1)關閉mysql服務,並且記錄下資料檔案目錄下的相關目錄和檔案的許可權
[root@L112 data]# service mysql stop
[root@L112 data]# ll
total 28748
-rw-rw----. 1 mysql mysql 18874368 May 27 17:15 ibdata1
-rw-rw----. 1 mysql mysql 5242880 May 27 17:15 ib_logfile0
-rw-rw----. 1 mysql mysql 5242880 May 17 17:20 ib_logfile1
-rw-r-----. 1 mysql root 65782 May 27 17:15 L112.err
drwx------. 2 mysql root 4096 May 17 17:12 mysql
drwx------. 2 mysql mysql 4096 May 17 17:12 performance_schema
drwx------. 2 mysql root 6 May 17 17:12 test
2)刪除mysql資料檔案目錄下的所有東西
[root@L112 data]# rm -rf *
3)執行恢復操作,
[root@L112 full]# innobackupex --copy-back /backup/mysqldump/full/back_26-05-2017/
其中
--copy-back代表複製回去,這樣原來的備份檔案依舊存在
--move-back代表移動回去,這樣原來的備份檔案就沒有了,可以節約空間
4)最重要的一步驟,需要修改目錄許可權,參照之前記錄的。
[root@L112 data]# chown -R mysql:root mysql/
[root@L112 data]# chown -R mysql:root liuwenhe/
[root@L112 data]# chown -R mysql:root test/
[root@L112 data]# chown mysql:mysql ibdata1
[root@L112 data]# chown mysql:mysql ibdata0
[root@L112 data]# chown mysql:mysql ib_logfile1
5)啟動資料庫:
[root@L112 data]# /etc/init.d/mysqld start
至此恢復過程已經完成,
至於只有全備的恢復相對來說是簡單的:就兩步驟,
1.apply-log應用日誌,保證一致性,
2.copy-back ,恢復。
具體如下:
innobackupex --defaults-file=/opt/mysql/my.cnf --user=root --password=*** --use-memory=4G --apply-log /backup/mysql/data/2013-10-29_09-05-25
innobackupex --defaults-file=/opt/mysql/my.cnf --user=root --password=*** --copy-back /backup/mysql/data/2013-10-29_09-05-25
從什麼可以看出,恢復分為兩個步驟,第1步是apply-log,為了加快速度,一般建議設定--use-memory,這個步驟完成之後,目錄/backup/mysql/data/2013-10-29_09-05-25下的備份檔案已經準備就緒。
第2步是copy-back,即把備份檔案複製至原資料目錄下。
恢復完成之後,一定要記得檢查資料目錄的所有者和許可權是否正確。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29654823/viewspace-2140008/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 【MySql】innobackupex增量備份和恢復MySql
- 【MySql】innobackupex 增量備份和恢復MySql
- mysql之 Innobackupex(全備+增量)備份恢復MySql
- 使用innobackupex線上增量備份和再增量備份及恢復mysql資料庫MySql資料庫
- MySQL innobackupex全量備份恢復MySql
- 【MySql】innobackupex 增量備份的bugMySql
- INNOBACKUPEX的全備和增量備份恢復學習筆記筆記
- Percona XtraBackup 2.4 innobackupex全量、增量備份恢復流程
- MySQL增量備份的指令碼(innobackupex)MySql指令碼
- innobackupex備份恢復實戰
- mysql 利用binlog增量備份、恢復MySql
- MySQL增量備份與恢復例項MySql
- 【Mysql】xbackup全量與增量備份恢復MySql
- 利用innobackupex備份集恢復指定庫
- oracle 增量備份恢復驗證Oracle
- Xtrabackup之innobackupex備份恢復詳解薦
- 【備份恢復】noarchive模式下使用增量備份恢復資料庫Hive模式資料庫
- Mysql備份系列(3)--innobackupex備份mysql大資料(全量+增量)操作記錄MySql大資料
- MySQL 5.6 xtrabackup 全量和增量的備份和恢復MySql
- innobackupex備份mysql大資料(全量+增量)操作記錄MySql大資料
- Mysql備份恢復MySql
- mysql 備份恢復MySql
- mysql innobackupex 物理備份MySql
- 【Xtrabackup】Xtrabackup全備、增量備份及恢復示例
- 透過innobackupex實現對MySQL的增量備份與還原MySql
- 【MySQL】MySQL備份和恢復MySql
- MySQL備份與恢復——基於Xtrabackup物理備份恢復MySql
- MySQL備份與恢復MySql
- Mysql備份和恢復MySql
- mysql innobackupex備份指令碼MySql指令碼
- Mysql增量備份MySql
- Mysql備份與恢復(1)---物理備份MySql
- oracle實驗記錄 (恢復-rman增量備份)Oracle
- Percona XtraBackup 實現全備&增量備份與恢復
- mysql之 innobackupex備份+binlog日誌的完全恢復(命令列執行模式)MySql命令列模式
- MySql邏輯備份恢復MySql
- Mysql的備份與恢復MySql
- mysql備份恢復測試MySql