mysql手工備份和自動備份

/##!/bin/bash
/#######################################################################
/## DATE: 2019-10-22 #
/## AUTHOR: zhangy_j #
/## FUNC: 判斷指定數據庫名,如未指定則退出該程序 #
/## 根據當前test測試數據庫進行備份指定數據庫 #
/## 該腳本可單獨運行,也可在每日11點和23點自動調用 #
/## #
/##-------------|------------------------------------------------------#
/#######################################################################
/##兩種備份,crontab中的自動備份和手工備份
/##默認按照文件datafile.db文件中數據庫進行備份,保留30天
/##手動備份方式,dbbak 數據庫名,例如:dbbak 11111,手動備份的文件保留7天
/#. /sbin/yujun/pswd >/dev/null 2>&1
/#export BAK=/tmp/yujun >/dev/null 2>&1
/#chmod 755 -R $BAK
/#DATAFILE=${BAK}/datafile.db
/#DATA_DIR=${BAK}
/#BAK_DIR=${BAK}/bak
/#BAK_DT=date +%Y%m%d
/#BAK_LOG=${BAK_DIR}/databak${BAK_DT}_log
/#FILE_DT=dbdate +%H
/#DB_USER='root'
/#############################Backup database host
/#DB_HOST="49.4.11.31"
/#D=$1
/#
/#
/#if [ x"$1" != x ]; then
/# #read -p "請輸入${DB_HOST}主機中需要備份的數據庫名 : " D
/# #read -p "請輸入${DB_HOST}主機中用戶用戶名 : " U
/# #read -p "請輸入${DB_HOST}主機中用戶密碼 : " P
/#
/#
/#
/# echo "-----【date "+%Y/%m/%d %H:%M:%S"】開始備份 $U 數據庫-----"
/# mysqldump --opt --single-transaction --master-data=2 -u$DB_USER -p$pass -h$DB_HOST ${D} > ${PWD}/${D}.sql
/# echo "-----【date "+%Y/%m/%d %H:%M:%S"】備份完成 $U 數據庫-----"
/#
/#
/#else
/#
/# ############################Database backup user
/# DB_USER='root'
/#
/#
/#
/#
/#
/# #Create backup directory
/# if [ ! -d ${BAK_DIR}/${BAK_DT} ]; then
/# mkdir -p ${BAK_DIR}/${BAK_DT} >/dev/null
/# fi
/#
/# if [ ! -f ${DATAFILE} ]
/# then
/# echo "$DATAFILE file does not exist! "
/# echo "請在$DATAFILE中輸入所有要備份的數據庫名!"
/#
/#
/# exit
/# fi
/#
/# print_log(){
/# MYDATE=date +"%Y-%m-%d %H:%M:%S"
/# case ${2} in
/# 1)
/# printf "%-40s%s\n" "$1" "$3$4$5$6$7$8${9}"
/# printf "%-40s%s\n" "$1" "$3$4$5$6$7$8${9}" >> ${BAK_LOG}
/# ;;
/# *)
/# echo "input error" >> ${BAK_LOG}
/# ;;
/# esac
/# }
/#
/# cd ${BAK_DIR} || exit
/#
/# #read -p "Please enter the database you want to back up : " DB
/#
/#
/# for i in cat $DATA_DIR/datafile.db
/# do
/# print_log "The database to be backed up is named: $i" "1"
/#
/# DB_FILE=${FILEDT}$i.sql
/#
/# echo "-----【date "+%Y/%m/%d %H:%M:%S"】開始備份 ${i} 數據庫-----" >>${BAK_LOG}
/# mysqldump --opt --single-transaction --master-data=2 -u$DB_USER -p$pass -h$DB_HOST ${i} > ${BAK_DIR}/${BAK_DT}/${DB_FILE}
/# echo "-----【date "+%Y/%m/%d %H:%M:%S"】備份完成 ${i} 數據庫,備份文件 ${DB_FILE}-----" >>${BAK_LOG}
/# done
/#
/#fi
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章