MySQL數據庫如何創建全庫及二進制增量備份腳本-創新互聯

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

成都創新互聯公司是一家專業提供寧安企業網站建設,專注與網站建設、成都做網站、H5網站設計、小程序制作等業務。10年已為寧安眾多企業、政府機構等服務。創新互聯專業網站建設公司優惠進行中。

1、全庫備份腳本如下:

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

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

######################  對選項進行賦值    ###################
while getopts ":u:p:h:d:" optname;do
case "$optname" in
"u")
   user=$OPTARG
;; 
"p")
   passwd=$OPTARG 
;;
"h")
   host=$OPTARG 
;;
"d")
   db=$OPTARG
;; 
":")
   echo "此選項沒有值!" 
;;
"*") 
   echo "錯誤信息..."
;;
"?")
   echo "不知道此選項..."
;;
esac
done

#############  對要備份的庫進行判斷并執行備份操作  ###############
[ -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

############  對備份狀態進行判斷  #####################
if [ ${status} -eq 0 ];then
   tar zcf ${sqlname}.tar.gz ./${sqlname}
   rm -f ${sqlname}
###########  如果失敗,則發送報警郵件到指定郵箱 ################
else
   echo "備份數據庫失敗,錯誤日志如上所示!!!" >> err.log
   mail -s "mysql backup" $email < err.log
fi

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

2、二進制增量備份腳本

#!/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的數據存放路徑
sum=`cat bin_log.index | wc -l`  #取得所有二進制日志文件總數
/usr/local/mysql/bin/mysql -u${user} -p${passwd} -e "flush logs" &> /dev/null  #在備份前刷新二進制日志文件

nextnum=0     #定義一個初始值為0
backupsum=0
for file in `cat bin_log.index`     #對所有二進制日志文件進行遍歷
do
   binlogname=`basename $file`     #獲取二進制日志文件名
#如果當前備份的文件數目比總數小(新刷新的二進制文件不需要備份)
   if [ $nextnum -lt $sum ];then  
   [ -f ${backupdir}${binlogname} ] || cp -a ${file} ${backupdir}${binlogname}  #如果備份目錄下不存在該二進制文件,則進行copy動作
   let nextnum++    #對備份成功數量進行增加
   fi
done

echo "跳過最新二進制日志文件,備份完成!!!"

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

當前名稱:MySQL數據庫如何創建全庫及二進制增量備份腳本-創新互聯
轉載來源:http://m.kartarina.com/article42/ccgchc.html

成都網站建設公司_創新互聯,為您提供Google小程序開發App開發移動網站建設全網營銷推廣靜態網站

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

h5響應式網站建設
主站蜘蛛池模板: 国产午夜无码片免费| 狠狠躁狠狠爱免费视频无码| 久久无码av三级| 无码一区二区三区在线观看| 亚洲精品无码av中文字幕| 自拍偷在线精品自拍偷无码专区 | 中文字幕久久久人妻无码 | 日本精品无码一区二区三区久久久 | 精品久久久久久无码中文字幕 | 久久久久无码国产精品一区| 亚洲AV无码国产精品色| av无码一区二区三区| 亚洲视频无码高清在线| 国产精品亚洲αv天堂无码| 在人线av无码免费高潮喷水| 亚洲国产综合无码一区| 精品久久亚洲中文无码| 高清无码视频直接看| 国产成人无码a区在线视频| 亚洲国产精品无码中文lv| 少妇无码一区二区二三区| 中文字幕人妻无码专区| av无码aV天天aV天天爽| 日韩放荡少妇无码视频| 亚洲中文字幕无码一去台湾| 久久亚洲AV成人无码国产 | 精品久久久无码人妻中文字幕| 加勒比无码一区二区三区| 亚洲成A人片在线观看无码3D| 内射人妻无套中出无码| 亚洲av无码偷拍在线观看| 99久久人妻无码精品系列| 无码囯产精品一区二区免费| 亚洲人成无码网WWW| 熟妇人妻中文a∨无码| 国产AV无码专区亚洲AV漫画| 国产aⅴ激情无码久久| 亚洲中文字幕无码久久2017 | 日韩人妻无码精品久久久不卡 | 亚洲熟妇无码AV不卡在线播放 | 亚洲日韩激情无码一区|