中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL數據庫如何用腳本備份全庫和增量備份

發布時間:2020-06-06 10:49:27 來源:億速云 閱讀:258 作者:Leah 欄目:MySQL數據庫

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

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 "跳過最新二進制日志文件,備份完成!!!"

以上就是MySQL數據庫用腳本備份全庫和增量備份的具體實現方法,看完之后是否有所收獲呢?如果想了解更多相關內容,歡迎關注億速云行業資訊!


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

眉山市| 邮箱| 濮阳县| 深水埗区| 依安县| 杭锦后旗| 海淀区| 盐源县| 陕西省| 宜都市| 海门市| 蒙自县| 郧西县| 托里县| 兴国县| 永胜县| 平顺县| 阜阳市| 会泽县| 西和县| 常州市| 宁化县| 重庆市| 怀来县| 郑州市| 淮南市| 广丰县| 霞浦县| 乾安县| 汾阳市| 长子县| 富平县| 仁化县| 青浦区| 河东区| 江安县| 江陵县| 仲巴县| 荆州市| 麻栗坡县| 苏尼特左旗|