久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

MySQL數據庫全庫備份及增量備份腳本

195次閱讀
沒有評論

共計 1931 個字符,預計需要花費 5 分鐘才能閱讀完成。

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
###################### 對選項進行賦值 ###################
while getopts “:u:p:h:d:” optname;do
case “$optname” in
user=$OPTARG
passwd=$OPTARG
host=$OPTARG
db=$OPTARG
echo “ 此選項沒有值!”
“*”)
echo “ 錯誤信息 …”
echo “ 不知道此選項 …”
############# 對要備份的庫進行判斷并執行備份操作 ###############
[-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”
${dump_cmd} -u${user} -p${passwd} -h${host} –databases $db -F ${today}.${db}.sql 2 err.log
status=$?
sqlname=”${today}.${db}.sql”
############ 對備份狀態進行判斷 #####################
if [${status} -eq 0 ];then
tar zcf ${sqlname}.tar.gz ./${sqlname}
rm -f ${sqlname}
########### 如果失敗,則發送報警郵件到指定郵箱 ################
echo “ 備份數據庫失敗,錯誤日志如上所示!??!” err.log
mail -s “mysql backup” $email err.log
############ 刪除二十天前的備份文件 ##############
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` #對所有二進制日志文件進行遍歷
 binlogname=`basename $file` #獲取二進制日志文件名
#如果當前備份的文件數目比總數?。ㄐ滤⑿碌亩M制文件不需要備份)if [$nextnum -lt $sum];then 
 [-f ${backupdir}${binlogname} ] || cp -a ${file} ${backupdir}${binlogname} #如果備份目錄下不存在該二進制文件,則進行 copy 動作
 let nextnum++ #對備份成功數量進行增加
echo "跳過最新二進制日志文件,備份完成?。?!"

向 AI 問一下細節

丸趣 TV 網 – 提供最優質的資源集合!

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-12-18發表,共計1931字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 台安县| 双辽市| 大庆市| 新竹市| 平阴县| 儋州市| 郑州市| 德化县| 平山县| 旬邑县| 安宁市| 云梦县| 深州市| 玛多县| 长兴县| 禄丰县| 南昌市| 安阳市| 象州县| 崇州市| 丹东市| 根河市| 宜都市| 灵山县| 陆良县| 营山县| 怀集县| 班玛县| 德格县| 文山县| 八宿县| 镇坪县| 清涧县| 旬邑县| 始兴县| 新沂市| 双鸭山市| 离岛区| 民乐县| 郸城县| 五莲县|