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

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

MySQL數(shù)據(jù)庫如何創(chuàng)建全庫及二進制增量備份腳本

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

成都創(chuàng)新互聯(lián)公司服務(wù)項目包括沙河口網(wǎng)站建設(shè)、沙河口網(wǎng)站制作、沙河口網(wǎng)頁制作以及沙河口網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,沙河口網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到沙河口省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

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: 指定要備份的數(shù)據(jù)庫(默認備份所有庫)
 \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

#############  對要備份的庫進行判斷并執(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)進行判斷  #####################
if [ ${status} -eq 0 ];then
    tar zcf ${sqlname}.tar.gz ./${sqlname}
    rm -f ${sqlname}
###########  如果失敗,則發(fā)送報警郵件到指定郵箱 ################
else
    echo "備份數(shù)據(jù)庫失敗,錯誤日志如上所示?。。? >> 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的數(shù)據(jù)存放路徑
sum=`cat bin_log.index | wc -l`   #取得所有二進制日志文件總數(shù)
/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`         #獲取二進制日志文件名
#如果當(dāng)前備份的文件數(shù)目比總數(shù)?。ㄐ滤⑿碌亩M制文件不需要備份)
    if [ $nextnum -lt $sum ];then   
    [ -f ${backupdir}${binlogname} ] || cp -a ${file} ${backupdir}${binlogname}   #如果備份目錄下不存在該二進制文件,則進行copy動作
    let nextnum++      #對備份成功數(shù)量進行增加
    fi
done

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


網(wǎng)站欄目:MySQL數(shù)據(jù)庫如何創(chuàng)建全庫及二進制增量備份腳本
標(biāo)題鏈接:http://weahome.cn/article/ihhepc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部