真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

MySQL數(shù)據(jù)庫如何用腳本備份全庫和增量備份-創(chuàng)新互聯(lián)

MySQL數(shù)據(jù)庫如何用腳本備份全庫和增量備份?針對這個(gè)問題,今天小編總結(jié)這篇有關(guān)數(shù)據(jù)庫備份的文章,可供感興趣的小伙伴們參考借鑒,希望對大家有所幫助。

創(chuàng)新互聯(lián)建站是專業(yè)的甘谷網(wǎng)站建設(shè)公司,甘谷接單;提供網(wǎng)站設(shè)計(jì)、成都網(wǎng)站設(shè)計(jì),網(wǎng)頁設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行甘谷網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!

1、全庫備份腳本如下:


#!/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: 指定備份用戶(默認(rèn)是root)
      -p: 指定用戶密碼(默認(rèn)密碼為“123.com”)
      -h: 指定備份主機(jī)(默認(rèn)是本機(jī))
      -d: 指定要備份的數(shù)據(jù)庫(默認(rèn)備份所有庫)
 \033[0m"
}

if [[ $1 == '--help' || $1 == '-h' ]];then
   USAGE
   exit 0
fi

######################  對選項(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)沒有值!" 
;;
"*") 
   echo "錯(cuò)誤信息..."
;;
"?")
   echo "不知道此選項(xiàng)..."
;;
esac
done

#############  對要備份的庫進(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

############  對備份狀態(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ù)庫失敗,錯(cuò)誤日志如上所示!?。? >> err.log
   mail -s "mysql backup" $email < err.log
fi

############  刪除二十天前的備份文件  ##############
find . -type f -name "*.tar.gz" -mtime +20 -delete

2、二進(jìn)制增量備份腳本

#!/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`     #對所有二進(jìn)制日志文件進(jìn)行遍歷 do   binlogname=`basename $file`     #獲取二進(jìn)制日志文件名 #如果當(dāng)前備份的文件數(shù)目比總數(shù)?。ㄐ滤⑿碌亩M(jìn)制文件不需要備份)   if [ $nextnum -lt $sum ];then     [ -f ${backupdir}${binlogname} ] || cp -a ${file} ${backupdir}${binlogname}  #如果備份目錄下不存在該二進(jìn)制文件,則進(jìn)行copy動(dòng)作   let nextnum++    #對備份成功數(shù)量進(jìn)行增加   fi done echo "跳過最新二進(jìn)制日志文件,備份完成!?。?

以上就是MySQL數(shù)據(jù)庫用腳本備份全庫和增量備份的具體實(shí)現(xiàn)方法,看完之后是否有所收獲呢?如果想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


本文標(biāo)題:MySQL數(shù)據(jù)庫如何用腳本備份全庫和增量備份-創(chuàng)新互聯(lián)
標(biāo)題路徑:http://weahome.cn/article/cdpcij.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部