腳本網盤連接下載。mysql
#!/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 "跳過最新二進制日誌文件,備份完成!!!"