腳本網盤鏈接下載。
成都創新互聯公司是一家專業提供燈塔企業網站建設,專注與做網站、成都網站制作、H5高端網站建設、小程序制作等業務。10年已為燈塔眾多企業、政府機構等服務。創新互聯專業網站設計公司優惠進行中。
#!/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
#!/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數據庫全庫備份及增量備份腳本
網頁路徑:http://m.newbst.com/article26/pogejg.html
成都網站建設公司_創新互聯,為您提供網站收錄、網頁設計公司、定制開發、App設計、全網營銷推廣、微信小程序
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯