欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

刪庫跑路?使用xtraback備份MySQL數(shù)據(jù)庫的方法

 更新時間:2018年10月25日 11:57:00   作者:輕松學習Linux  
mysqldump備份方式是采用邏輯備份,最大的缺陷就是備份和恢復的速度都慢,這時候就需要一種很好用又高效的工具,xtraback 就是其中的一款,號稱免費版的innodb hotbackup。接下來通過本文給大介紹使用xtraback備份MySQL數(shù)據(jù)庫的方法,感興趣的朋友一起看看吧

一、mysqldump備份方式是采用邏輯備份。最大的缺陷就是備份和恢復的速度都慢,對于一個50G的數(shù)據(jù)庫而言,這個速度還是可以接受的,但是如果數(shù)據(jù)庫非常大,那在使用mysqdump備份就不是太合適了。。

這時候就需要一種很好用又高效的工具,xtraback 就是其中的一款,號稱免費版的innodb hotbackup

xtraback特點如下:

  • 備份過程快速,可靠
  • 備份過程不會打斷正在執(zhí)行的事務
  • 能夠基于壓縮等功能節(jié)約磁盤空間和流量
  • 自動實現(xiàn)備份檢驗
  • 還原速度快

二、安裝xtraback 1)下載xtraback

wget https://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2.4.4/binary/tarball/percona-xtrabackup-2.4.4-Linux-x86_64.tar.gz 

2)解壓

[root@master ~]# tar zxf percona-xtrabackup-2.4.4-Linux-x86_64.tar.gz 

3)進入解壓目錄復制bin下的所有程序到/usr/bin下即可

[root@master ~]# cd percona-xtrabackup-2.4.4-Linux-x86_64/ [root@master percona-xtrabackup-2.4.4-Linux-x86_64]# cp bin/* /usr/bin/ 

xtraback是用于熱備份innodb,xtradb表中數(shù)據(jù)的工具,支持在線熱備份,可以在不加鎖的情況下備份innodb數(shù)據(jù)表,不過此工具不能操作myisam引擎表

4)安裝相關的插件

yum install perl-DBI perl-DBD-MySQL perl-Time-HiRes perl-IO-Socket-SSL perl-TermReadKey.x86_64 perl-Digest-MD5 –y 

5)下載percona-toolkit并安裝

wget https://www.percona.com/downloads/percona-toolkit/2.2.19/RPM/percona-toolkit-2.2.19-1.noarch.rpm 
[root@master ~]# rpm -ivh percona-toolkit-2.2.19-1.noarch.rpm warning: percona-toolkit-2.2.19-1.noarch.rpm: Header V4 DSA/SHA1 Signature, key ID cd2efd2a: NOKEY Preparing... ################################# [100%] Updating / installing...  
1:percona-toolkit-2.2.19-1 ################################# [100%] 

三、備份

方案一:xtrabackup完全備份+binlog增量備份 (需要開啟bin-log日志)

創(chuàng)建備份目錄

[root@master ~]# mkdir -p /opt/mysqlbackup/{full,inc} 

首先我們創(chuàng)一個test庫,在test庫中創(chuàng)建一個tb1的表,在tb1表中插入三行數(shù)據(jù),如下:

插入數(shù)據(jù)后我們進行完全備份 如下:

[root@master ~]# 
innobackupex --user=root --password=pwd123 /opt/mysqlbackup/full/ 

以上完全備份路徑為我們剛剛創(chuàng)建的mysqlbackup目錄下。

出現(xiàn)以下提示證明備份成功

備份后的文件如下:

至此全備完全成功,然后向mysql某個庫插入幾條數(shù)據(jù),然后進行增量備份

對完全備份的后數(shù)據(jù)庫更改進行二進制日志增量備份:

查看完全備份時binlog日志位置(position):

以上就是我們完全備份完成后的位置,那么如果我們現(xiàn)在插入數(shù)據(jù)的話,是從這個位置開始的,從這個位置開始的我們稱為增量備份,現(xiàn)在我們在tb1表中插入數(shù)據(jù)如下:

增量備份二進制文件:

[root@master ~]
# mysqlbinlog --start-position=1279 /usr/local/mysql/data/mysql-bin.000001 > /opt/mysqlbackup/inc/`date +%F`.sql 

備份完成后,我們模擬數(shù)據(jù)庫損壞,誤刪操作,如下

[root@master ~]# rm -rf /usr/local/mysql/data/* 

恢復數(shù)據(jù)庫

首先恢復我們的完全備份,也就是tom1/2/3的數(shù)據(jù) 如下:

[root@master ~]#innobackupex --copy-back /opt/mysqlbackup/full/2017-11-21_11-47-42/ 

出現(xiàn)以下提示證明還原成功

當數(shù)據(jù)恢復至DATADIR目錄以后,還需要確保所有數(shù)據(jù)文件的屬主和屬組均為正確的用戶,如mysql,否則,在啟動mysqld之前還需要事先修改數(shù)據(jù)文件的屬主和屬組。如:

# chown -R mysql:mysql /usr/local/mysql/data/ 

重啟mysql服務查看是否還原成功

以上看出完全備份已經(jīng)還原成功,因為我們在完全備份的時候插入了3行數(shù)據(jù),那么接下來我們還原增量備份如下:

為了防止還原時產生大量的二進制日志,在還原時可臨時關閉二進制日志后再還原:

隨后我們驗證是否還原成功!

此時我們已經(jīng)全部恢復成功,以上通過binlog+xtrabackup工具來實現(xiàn)的備份,是不是感覺有點小麻煩。如感覺到麻煩請看-以下方案二。

二、xtrabackup完全備份+xtrabacup增量備份

測試環(huán)境準備

創(chuàng)建一個測試數(shù)據(jù)庫,并創(chuàng)建一張表輸入幾行數(shù)據(jù)

以上操作解釋:

創(chuàng)建了一個test庫,在test庫中創(chuàng)建了xx表,在xx表中插入了tom1和tom2的數(shù)據(jù)。

接下來執(zhí)行完全備份如下:

[root@master ~]# xtrabackup --defaultes-file=/etc/my.cnf --user=root --password='pwd123' --popt=3306 --backup --target-dir=/opt/mysqlbackup/full/full_incre_$(date +%Y%m%d_%H%M%S) 

以上黑色部分是存放位置。出現(xiàn)以下證明備份成功

這時候我們再次插入數(shù)據(jù),進行一次增量備份

備份第一次增量如下:

[root@master ~]# xtrabackup --defaultes-file=/etc/my.cnf --user=root --password='pwd123' --popt=3306 --backup --target-dir=/opt/mysqlbackup/inc/inc_incre_$(date +%Y%m%d_%H%M%S) --incremental-basedir=/opt/mysqlbackup/full/full_incre_20171121_123051/ 

出現(xiàn)以下表示備份成功!

以上備份路徑為:/opt/mysqlbackup/inc/我們可以查看備份的文件

接下來在xx表中再次插入數(shù)據(jù),進行第二次增量備份

第二次增量備份如下:

[root@master ~]# xtrabackup --defaultes-file=/etc/my.cnf --user=root --password='pwd123' --popt=3306 --backup --target-dir=/opt/mysqlbackup/inc/inc_incre_$(date +%Y%m%d_%H%M%S) --incremental-basedir=/opt/mysqlbackup/inc/inc_incre_20171121_124604/ 

出現(xiàn)以下提示證明備份成功

xtrabacup進行增量恢復

為了實現(xiàn)效果我把xx表刪了

開始恢復完全備份如下:

[root@master ~]# xtrabackup --defaultes-file=/etc/my.cnf --prepare --user=root --password="pwd123" --apply-log-only --target-dir=/opt/mysqlbackup/full/full_incre_20171121_123051 

二、恢復第一次增量(tom3)

[root@master ~]# xtrabackup --defaultes-file=/etc/my.cnf --prepare --user=root --password="pwd123" --apply-log-only --target-dir=/opt/mysqlbackup/full/full_incre_20171121_123051 --incremental-dir=/opt/mysqlbackup/inc/inc_incre_20171121_124604/ 

三、恢復第二次增量

[root@master ~]# xtrabackup --defaultes-file=/etc/my.cnf --prepare --user=root --password="pwd123" --apply-log-only --target-dir=/opt/mysqlbackup/full/full_incre_20171121_123051 --incremental-dir=/opt/mysqlbackup/inc/inc_incre_20171121_125202 

恢復整個庫

[root@master ~]# xtrabackup --defaultes-file=/etc/my.cnf --prepare --user=root --password="pwd123" --target-dir=/opt/mysqlbackup/full/full_incre_20171121_123051 

停止mysql數(shù)據(jù)庫-開始rsync數(shù)據(jù)文件

[root@master ~]# systemctl stop mysqld [root@master ~]# cd /opt/mysqlbackup/full/full_incre_20171121_123051/ [root@master full_incre_20171121_123051]# rsync -rvt --exclude 'xtrabackup_checkpoints' --exclude 'xtrabackup_logfile' ./ /usr/local/mysql/data/ 

授予mysql訪問權限

[root@master ~]# chown -R mysql:mysql /usr/local/mysql/data/ 

啟動mysql服務查看還原是否成功

總結

以上所述是小編給大家介紹的刪庫跑路?使用xtraback備份MySQL數(shù)據(jù)庫的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關文章

  • 詳解MySQL(InnoDB)是如何處理死鎖的

    詳解MySQL(InnoDB)是如何處理死鎖的

    這篇文章主要介紹了MySQL(InnoDB)是如何處理死鎖的,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • MySQL中導出用戶權限設置的腳本分享

    MySQL中導出用戶權限設置的腳本分享

    這篇文章主要介紹了MySQL中導出用戶權限設置的腳本分享,本文通過導出mysql.user表中數(shù)據(jù)實現(xiàn)導出權限設置,需要的朋友可以參考下
    2014-10-10
  • mysql select緩存機制使用詳解

    mysql select緩存機制使用詳解

    這篇文章主要介紹了mysql select緩存機制使用詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • MyBatis攔截器實現(xiàn)分頁功能的實現(xiàn)方法

    MyBatis攔截器實現(xiàn)分頁功能的實現(xiàn)方法

    這篇文章主要介紹了MyBatis攔截器實現(xiàn)分頁功能的實現(xiàn)方法的相關資料,希望通過本文大家能夠實現(xiàn)這樣的方法,需要的朋友可以參考下
    2017-10-10
  • MySQL?人臉向量歐幾里得距離相似查詢步驟梳理

    MySQL?人臉向量歐幾里得距離相似查詢步驟梳理

    這篇文章主要為大家介紹了MySQL?人臉向量歐幾里得距離相似查詢步驟梳理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • MySQL服務器連接過程淺析

    MySQL服務器連接過程淺析

    這篇文章主要介紹了MySQL服務器連接過程淺析,本文從源碼分析了MySQL服務器的連接過程,需要的朋友可以參考下
    2015-03-03
  • mysql事務隔離級別詳解

    mysql事務隔離級別詳解

    MySQL事務隔離級別是指在多個事務同時執(zhí)行時,數(shù)據(jù)庫系統(tǒng)如何處理這些事務之間的相互影響。MySQL提供了四種隔離級別:讀未提交、讀已提交、可重復讀和串行化。每種隔離級別都有其優(yōu)缺點,需要根據(jù)具體情況選擇合適的級別。
    2023-06-06
  • mysql group by having 實例代碼

    mysql group by having 實例代碼

    mysql中group by語句用于分組查詢,可以根據(jù)給定數(shù)據(jù)列的每個成員對查詢結果進行分組統(tǒng)計,最終得到一個分組匯總表, 經(jīng)常和having一起使用,需要的朋友可以參考下
    2016-11-11
  • MySQL 刪除數(shù)據(jù)庫中重復數(shù)據(jù)方法小結

    MySQL 刪除數(shù)據(jù)庫中重復數(shù)據(jù)方法小結

    在實際項目中,我們經(jīng)常會遇到刪除數(shù)據(jù)庫中重復數(shù)據(jù)的問題,貌似是很簡單的問題哈,下面我們來探討下
    2014-07-07
  • 運用mysqldump 工具時需要注意的問題

    運用mysqldump 工具時需要注意的問題

    用mysqldump 導出 Trigger 的時候遇到一個問題,貼出來,以免大家犯錯。
    2009-07-07

最新評論