国产成人精品18p,天天干成人网,无码专区狠狠躁天天躁,美女脱精光隐私扒开免费观看

mysql怎么增量備份和恢復數據

發(fā)布時(shí)間:2021-08-23 15:07 來(lái)源:億速云 閱讀:0 作者:chen 欄目: Mysql 歡迎投稿:712375056

這篇文章主要介紹“怎么增量備份和恢復數據”,在日常操作中,相信很多人在mysql怎么增量備份和恢復數據問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對大家解答”mysql怎么增量備份和恢復數據”的疑惑有所幫助!接下來(lái),請跟著(zhù)小編一起來(lái)學(xué)習吧!

全備:

[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

增量備份兩個(gè):

[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庫已經(jīng)被刪除掉了。

下面展示具體恢復的過(guò)程。。。。。。。。

恢復:

整個(gè)過(guò)程分為三步驟,整體上可以理解為:先把增量備份的數據倒進(jìn)全備份中,然后最后使用全備份恢復即可,

第一步:是在所有備份目錄下重做已提交的日志,注意最后一個(gè)增量備份是沒(méi)有--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

或者

加上用戶(hù)名和密碼,以及使用的配置文件:

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是指第二次的增量備份,以此類(lèi)推。這里要注意的是:最后一步的增量備份并沒(méi)有--redo-only選項!還有,可以使用--use_memory提高性能。

以上語(yǔ)句執行成功之后,最終數據在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/

第二步:回滾未完成的日志,也就是已經(jīng)刷新到磁盤(pán)的,但是還沒(méi)有提交的。

innobackupex --apply-log BASE-DIR

我的具體操作:

[root@L112 full]# innobackupex --apply-log  /backup/mysqldump/full/back_26-05-2017/

上面執行完之后,BASE-DIR里的備份文件已完全準備就緒,

最后一步:是拷貝,這個(gè)步驟需要注意先把數據庫關(guān)掉,并且把數據文件和日志文件刪除:

innobackupex --copy-back BASE-DIR

我的具體操作是:

1)關(guān)閉mysql服務(wù),并且記錄下數據文件目錄下的相關(guān)目錄和文件的權限

[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代表拷貝回去,這樣原來(lái)的備份文件依舊存在

--move-back代表移動(dòng)回去,這樣原來(lái)的備份文件就沒(méi)有了,可以節約空間

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)啟動(dòng)數據庫:

[root@L112 data]#  /etc/init.d/mysqld start

至此恢復過(guò)程已經(jīng)完成,

至于只有全備的恢復相對來(lái)說(shuō)是簡(jiǎn)單的:就兩步驟,

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

從什么可以看出,恢復分為兩個(gè)步驟,第1步是apply-log,為了加快速度,一般建議設置--use-memory,這個(gè)步驟完成之后,目錄/backup/mysql/data/2013-10-29_09-05-25下的備份文件已經(jīng)準備就緒。

第2步是copy-back,即把備份文件拷貝至原數據目錄下。

恢復完成之后,一定要記得檢查數據目錄的所有者和權限是否正確。

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。

啊灬啊灬啊灬快灬深高潮了| 亚洲中文字幕无码天然素人在线| JLZZJLZZ亚洲乱熟无码| AV无码小缝喷白浆在线观看| 中文字幕无码视频手机免费看| 精品无码人妻一区二区三区不卡|