MySQL自動備份整庫腳本

該腳本支持自動備份,自動上傳到FTP服務器,備份失敗自動發送報警郵件


#!/bin/sh
#Create by JIANGLEI.YU  ON 20160421
#使用測腳本需要先安裝mutt郵件發送工具。
#使用使用自動化安裝。詳細請參考 http://yujianglei.blog.51cto.com/7215578/1765938
#Define MySQL  Environments
Hostname='192.168.0.141'
Port='3306'
Username='root'
Password='123456'
Mysqldump=$(which mysqldump)
Gzip=$(which gzip)
Destinaion_dir='/home/bak/database/data'
Timestamp=$(date +%Y%m%d%H%M%S)
Database='virtual'
Alarm_User="[email protected]"
File_Name="$Timestamp-$Database.sql.gz"
#File_Name="20160421110453-virtualsdk.sql.gz"
#Define Ftp  Environments
Ftp_Host='192.168.0.136'
Ftp_Port='21'
Ftp_User='yujianglei'
Ftp_Pass='yujianglei'
RPM=$(which rpm)
function check_result(){
        if [ $? != 0 ];then
            echo  "Backup Database Failed"     | mutt -s "$Database Backup Database Failed"      ${Alarm_User}
            exit 1
        else
            echo  "Backup Database Successful" | mutt -s "$Database Backup Database Successful"  ${Alarm_User}
            
        fi
}
function bakcup(){
    [ ! -d ${Destinaion_dir} ] && mkdir -p ${Destinaion_dir}
    Cmd="$Mysqldump -h$Hostname -p$Port -u$Username -p$Password"
    Parameter="--flush-privileges --opt -R -E  --triggers --single-transaction -F"
    $Cmd $Parameter $Database  | gzip >${Destinaion_dir}/${File_Name}
    check_result $?
}
function upload_ftp(){
    $RPM -q  ftp  
    [ $? != 0 ] && yum install ftp -y
    ftp -n ${Ftp_Host} ${Ftp_Port} << END
    user ${Ftp_User} $Ftp_Pass
    lcd ${Destinaion_dir}
    cd   database
    put ${File_Name}
    quit
END
    check_result $?
    exit 0
}
bakcup
upload_ftp


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章