1. 程式人生 > >企業實戰:mysql5.6數據庫備份、恢復腳本

企業實戰:mysql5.6數據庫備份、恢復腳本

ash path bsp mat fun fin sql wait user

一、mysql數據庫備份腳本

備份腳本1:

[root@szxelab-a-back-12 scripts]# vim elab_fenku_backup.sh
#!/bin/sh
#create at 2018-01-08
#author oldboy
#qq 88888

echo "--------------------------ychfq:`date +%F-%H`--------------------------"

DB_USER="oldboy_bak"
DB_PWD="123456"
DB_PROT="3306"
DB_HOST="ro-oldboy.mysql.rds.aliyuncs.com"
BACKUP_DIR="/data/backup/mysql"


if [ ! -d $BACKUP_DIR ];then
    echo "$BACKUP_DIR:No such file or directory" && exit 2
else
    for dbname in `mysql -u"$DB_USER" -p"$DB_PWD" -h"$DB_HOST" -P"$DB_PROT" -e "show databases;"     |egrep -v "Database|information_schema|performance_schema|mysql|mysq"`
    do
        #備份存儲過程、函數等
        mysqldump -u"$DB_USER" -p"$DB_PWD" -h"$DB_HOST" -P"$DB_PROT" --opt --default-character-set=utf8 --hex-blob --triggers -d -t -R $dbname         |sed -e 's/DEFINER[ ]*=[ ]*[^*]*\*/\*/'|gzip>$BACKUP_DIR/"$dbname"_func_$(date +%Y%m%d%H).sql.gz

        #copy存儲過程、函數到公司內網服務器
        scp -r -p -P 52119 $BACKUP_DIR/"$dbname"_func_$(date +%Y%m%d%H).sql.gz [email protected]:/data/mysqlbak/ &


        #備份視圖、數據
        mysqldump -u"$DB_USER" -p"$DB_PWD" -h"$DB_HOST" -P"$DB_PROT" --opt --default-character-set=utf8 --hex-blob --skip-triggers $dbname         |sed -e 's/DEFINER[ ]*=[ ]*[^*]*\*/\*/'|gzip>$BACKUP_DIR/"$dbname"_data_$(date +%Y%m%d%H).sql.gz

        #copy視圖、數據到公司內網服務器
        scp -r -p -P 52119 $BACKUP_DIR/"$dbname"_data_$(date +%Y%m%d%H).sql.gz [email protected]:/data/mysqlbak/ &


    done
fi

wait
find $BACKUP_DIR -mtime +3 -type f -name "*.sql.gz" |xargs rm -f

備份腳本2:

[root@szxelab-a-back-12 scripts]# cat elab_fenku_backup.sh
#!/bin/sh
#create at 2018-01-08
#author oldboy
#qq 88888

echo "--------------------------ychfq:`date +%F-%H`--------------------------"

DB_USER="elab_bak"
DB_PWD="123456"
DB_PROT="53306"
DB_HOST="oldboycom.mysql.rds.aliyuncs.com"
BACKUP_DIR="/data/backup/mysql"


if [ ! -d $BACKUP_DIR ];then
    echo "$BACKUP_DIR:No such file or directory" && exit 2
else
    for dbname in `mysql -u"$DB_USER" -p"$DB_PWD" -h"$DB_HOST" -P"$DB_PROT" -e "show databases;"     |egrep -v "Database|information_schema|performance_schema|mysql|mysq"`
    do 
        #備份存儲過程、函數等
        mysqldump -u"$DB_USER" -p"$DB_PWD" -h"$DB_HOST" -P"$DB_PROT" --opt --default-character-set=utf8 --hex-blob --triggers -d -t -R $dbname         |sed -e 's/DEFINER[ ]*=[ ]*[^*]*\*/\*/'|gzip>$BACKUP_DIR/"$dbname"_func_$(date +%Y%m%d%H).sql.gz
        #copy存儲過程、函數到公司內網服務器
        scp -r -p -P 52119 $BACKUP_DIR/"$dbname"_func_$(date +%Y%m%d%H).sql.gz [email protected]:/data/mysqlbak/ &
        

        #備份視圖、數據
        mysqldump -u"$DB_USER" -p"$DB_PWD" -h"$DB_HOST" -P"$DB_PROT" --opt --default-character-set=utf8 --hex-blob --skip-triggers $dbname         |sed -e 's/DEFINER[ ]*=[ ]*[^*]*\*/\*/'|gzip>$BACKUP_DIR/"$dbname"_data_$(date +%Y%m%d%H).sql.gz
        #copy視圖、數據到公司內網服務器
        scp -r -p -P 52119 $BACKUP_DIR/"$dbname"_data_$(date +%Y%m%d%H).sql.gz [email protected]:/data/mysqlbak/ &
         

    done
fi

wait
find $BACKUP_DIR -mtime +3 -type f -name "*.sql.gz" |xargs rm -f

二、恢復腳本

[root@analysis ~]# cat /scripts/mysql_import.sh
#!/bin/sh

#author  billy
#time    2017-01-10
#version 1.0

MYSQL_PATH=/application/mysql/bin

cd /scripts
echo "---------------------------------$(date +%F)-------------------------------------" 

/usr/bin/scp -r -p -P53306 [email protected]:/data/mysqlbak/*_$(date +%Y%m%d)01.sql.gz /scripts
#/usr/bin/scp -r -p [email protected]:/data/mysqlbak/youyadai_$(date +%Y%m%d)01.sql.gz /scripts

/bin/gzip -d *_$(date +%Y%m%d)01.sql.gz
#/bin/gzip -d yyd_$(date +%Y%m%d)01.sql.gz


$MYSQL_PATH/mysql -uroot -p'123456' yyd <youyadai_data_$(date +%Y%m%d)01.sql
$MYSQL_PATH/mysql -uroot -p'123456' yyd <youyadai_func_$(date +%Y%m%d)01.sql

#$MYSQL_PATH/mysql -uroot -p'123456' ych <ychfq_data_$(date +%Y%m%d)01.sql
$MYSQL_PATH/mysql -uroot -p'123456' ych <ychfq_func_$(date +%Y%m%d)01.sql

$MYSQL_PATH/mysql -uroot -p'123456' lending_account <lending_account_func_$(date +%Y%m%d)01.sql
$MYSQL_PATH/mysql -uroot -p'123456' lending_account <lending_account_data_$(date +%Y%m%d)01.sql

/bin/rm -f /scripts/*_$(date +%Y%m%d)01.sql

echo "---------------------------------end-------------------------------------"


企業實戰:mysql5.6數據庫備份、恢復腳本