下面講講關(guān)于MySQL數(shù)據(jù)庫(kù)如何創(chuàng)建全庫(kù)及二進(jìn)制增量備份腳本,文字的奧妙在于貼近主題相關(guān)。所以,閑話就不談了,我們直接看下文吧,相信看完MySQL數(shù)據(jù)庫(kù)如何創(chuàng)建全庫(kù)及二進(jìn)制增量備份腳本這篇文章你一定會(huì)有所受益。

#!/bin/bash
############### 定義默認(rèn)值 #################
user='root'
passwd='123.com'
host='localhost'
today=`date '+%F'`
dump_cmd='/usr/local/mysql/bin/mysqldump'
full_backupdir="/opt/database/full_backup/"
email='916551516@qq.com'
################### 加載變量并定義腳本用法 ###################
USAGE(){
echo -e "\033[33m
$0 腳本用法:
-u: 指定備份用戶(hù)(默認(rèn)是root)
-p: 指定用戶(hù)密碼(默認(rèn)密碼為“123.com”)
-h: 指定備份主機(jī)(默認(rèn)是本機(jī))
-d: 指定要備份的數(shù)據(jù)庫(kù)(默認(rèn)備份所有庫(kù))
\033[0m"
}
if [[ $1 == '--help' || $1 == '-h' ]];then
USAGE
exit 0
fi
###################### 對(duì)選項(xiàng)進(jìn)行賦值 ###################
while getopts ":u:p:h:d:" optname;do
case "$optname" in
"u")
user=$OPTARG
;;
"p")
passwd=$OPTARG
;;
"h")
host=$OPTARG
;;
"d")
db=$OPTARG
;;
":")
echo "此選項(xiàng)沒(méi)有值!"
;;
"*")
echo "錯(cuò)誤信息..."
;;
"?")
echo "不知道此選項(xiàng)..."
;;
esac
done
############# 對(duì)要備份的庫(kù)進(jìn)行判斷并執(zhí)行備份操作 ###############
[ -d ${full_backupdir} ] || mkdir -p ${full_backupdir}
cd ${full_backupdir}
: > err.log
if [ ${#db} -eq 0 ];then
${dump_cmd} -u${user} -p${passwd} -h${host} -A -F > ${today}.sql 2> err.log
status=$?
sqlname="${today}.sql"
else
${dump_cmd} -u${user} -p${passwd} -h${host} --databases $db -F > ${today}.${db}.sql 2> err.log
status=$?
sqlname="${today}.${db}.sql"
fi
############ 對(duì)備份狀態(tài)進(jìn)行判斷 #####################
if [ ${status} -eq 0 ];then
tar zcf ${sqlname}.tar.gz ./${sqlname}
rm -f ${sqlname}
########### 如果失敗,則發(fā)送報(bào)警郵件到指定郵箱 ################
else
echo "備份數(shù)據(jù)庫(kù)失敗,錯(cuò)誤日志如上所示!!!" >> err.log
mail -s "mysql backup" $email < err.log
fi
############ 刪除二十天前的備份文件 ##############
find . -type f -name "*.tar.gz" -mtime +20 -delete#!/bin/bash
####################### 定義初始值 #############################
user='root'
passwd='123.com'
datadir="/usr/local/mysql/data"
backupdir="/opt/database/dailybackup/"
dump_cmd='/usr/local/mysql/bin/mysqlbinlog'
[ -d ${backupdir} ] || mkdir -p ${backupdir} #判斷備份文件存放路徑是否存在
cd ${datadir} #切換至mysql的數(shù)據(jù)存放路徑
sum=`cat bin_log.index | wc -l` #取得所有二進(jìn)制日志文件總數(shù)
/usr/local/mysql/bin/mysql -u${user} -p${passwd} -e "flush logs" &> /dev/null #在備份前刷新二進(jìn)制日志文件
nextnum=0 #定義一個(gè)初始值為0
backupsum=0
for file in `cat bin_log.index` #對(duì)所有二進(jìn)制日志文件進(jìn)行遍歷
do
binlogname=`basename $file` #獲取二進(jìn)制日志文件名
#如果當(dāng)前備份的文件數(shù)目比總數(shù)小(新刷新的二進(jìn)制文件不需要備份)
if [ $nextnum -lt $sum ];then
[ -f ${backupdir}${binlogname} ] || cp -a ${file} ${backupdir}${binlogname} #如果備份目錄下不存在該二進(jìn)制文件,則進(jìn)行copy動(dòng)作
let nextnum++ #對(duì)備份成功數(shù)量進(jìn)行增加
fi
doneecho "跳過(guò)最新二進(jìn)制日志文件,備份完成!!!"
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性?xún)r(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿(mǎn)足用戶(hù)豐富、多元化的應(yīng)用場(chǎng)景需求。
當(dāng)前名稱(chēng):MySQL數(shù)據(jù)庫(kù)如何創(chuàng)建全庫(kù)及二進(jìn)制增量備份腳本-創(chuàng)新互聯(lián)
轉(zhuǎn)載來(lái)源:http://chinadenli.net/article42/ccgchc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供Google、小程序開(kāi)發(fā)、App開(kāi)發(fā)、移動(dòng)網(wǎng)站建設(shè)、全網(wǎng)營(yíng)銷(xiāo)推廣、靜態(tài)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容