Percona XtraBackup(簡(jiǎn)稱PXB)是最常用的MySQL物理熱備工具之一,并且是完全開(kāi)源的。軟件安裝好后,bin目錄下的文件如下所示:(版本為2.4.9)
在2.3版本之后,xtrabackup可同時(shí)用來(lái)備份innodb表和非innodb表,且會(huì)與mysqld server進(jìn)行交互,如加讀鎖(FTWRL)、獲取位點(diǎn)(SHOW SLAVE STATUS)等;
Innobackupex是作為xtrabackup的軟連接;
xbcrypt是用來(lái)加密或解密;
xbstream是Percona實(shí)現(xiàn)的用于將備份輸出格式轉(zhuǎn)換為流文件的格式。
將xtrabackup.tar.gz安裝包和qpress文件上傳到/opt目錄下并解壓,然后設(shè)置軟連接即可使用。
ln -s /opt/xtrabackup/bin/xtrabackup /usr/bin/innobackupex
ln -s /opt/xtrabackup/bin/xtrabackup /usr/bin/xtrabackup
ln -s /opt/xtrabackup/bin/xbstream /usr/bin/xbstream
cp /opt/qpress /usr/bin/ (qpress屬主為root用戶,權(quán)限為755)
--defaults-file # 指定配置文件,這個(gè)參數(shù)要放在第一位
--socket # 指定socket文件
-u # 指定用戶名
-p # 指定密碼
--compress # 啟用壓縮
--compress-threads =3 # 指定同時(shí)壓縮的線程數(shù)量
--compress-chunk-size=1024K # 指定壓縮的緩沖區(qū)大小
--parallel=8 # 指定啟動(dòng)并發(fā)備份線程的數(shù)量(一個(gè)數(shù) 據(jù)文件只會(huì)有一個(gè)進(jìn)程完成備份)
--slave-info # 打印出master的名字和位點(diǎn)信息,并記錄到 xtrabackup_slave_info文件中
--stream=tar,xbstream # 指定流備份格式
Xtrabackup的stream參數(shù)可以實(shí)現(xiàn)將備份以指定的tar或stream格式輸出到STDOUT(標(biāo)準(zhǔn)輸出),基于此,可以使用管道符和其他程序來(lái)過(guò)濾備份的輸出,為備份的存儲(chǔ)提供更大的靈活性。
innobackupex --defaults-file=/data/mysql/db_master01/conf/master01.cnf --socket=/data/mysql/db_master01/mysql.sock -uroot -p123456 --stream=tar /tmp > /data/DBbackup/master01/master_tar.tar
注:“/tmp”是流備份產(chǎn)生的臨時(shí)文件存儲(chǔ)的路徑。
當(dāng)使用tar格式的流備份時(shí),直接使用“--compress”參數(shù)來(lái)進(jìn)行壓縮會(huì)提示不兼容報(bào)錯(cuò),報(bào)錯(cuò)截圖如下所示:
此時(shí)可以使用管道符和Linux環(huán)境下的壓縮命令來(lái)完成壓縮,命令如下:
innobackupex --defaults-file=/data/mysql/db_master01/conf/master01.cnf --socket=/data/mysql/db_master01/mysql.sock -uroot -p123456 --stream=tar /tmp | gzip - > /data/DBbackup/master01/master_gzip.tar.gz
可以比較一下壓縮后備份文件的大小:
innobackupex --defaults-file=/data/mysql/db_master01/conf/master01.cnf --socket=/data/mysql/db_master01/mysql.sock -uroot -p123456 --compress --compress-threads=3 --parallel=8 --stream=xbstream /tmp > /data/DBbackup/master01/master_xbstream.xbstream
查看備份文件大?。?/span>
從歸檔文件中提取備份:
xbstream -x < master_xbstream.xbstream -C /data/DBbackup/master01
可以使用管道符搭配SSH命令,將備份數(shù)據(jù)流傳輸?shù)竭h(yuǎn)程主機(jī),命令如下:
innobackupex --defaults-file=/data/mysql/db_master01/conf/master01.cnf --socket=/data/mysql/db_master01/mysql.sock -uroot -p123456 --compress --compress-threads=3 --parallel=8 --stream=xbstream /tmp | ssh [email protected] "cat - > /data/master01/master_remote.xbstream"
登錄遠(yuǎn)程主機(jī),查看備份文件:
更多精彩干貨分享
點(diǎn)擊下方名片關(guān)注
IT那活兒
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/129849.html
閱讀 1356·2023-01-11 13:20
閱讀 1707·2023-01-11 13:20
閱讀 1215·2023-01-11 13:20
閱讀 1906·2023-01-11 13:20
閱讀 4165·2023-01-11 13:20
閱讀 2757·2023-01-11 13:20
閱讀 1402·2023-01-11 13:20
閱讀 3671·2023-01-11 13:20