自动备份Mysql数据库脚本

#!/bin/bash
#2021年03月12日08:55:05
#auto backup mysql database
#by author chenshubin
########################
DB_NAME="$*"
DB_PORT=3380
DB_USR="test_db"
DB_PASS="fCrCzIa7w6JkeMjrHucg"
DB_CMD="/usr/bin/mysqldump"
DB_BAK="/data/backup/`date +%F`"
if [ $# -eq 0 ];then
    echo -e "\033[32m---------------------------------\033[0m"
    echo -e "\033[32mUsage:{/bin/sh $0 DB01|DB02|help}\033[0m"
    exit 1
fi
if [ ! -d $DB_BAK ];then
    mkdir -p $DB_BAK
fi

for i in $(echo $DB_NAME|sed 's/ /\n/g'|sort -nr)
do
    if [ $i == "all" ];then
            $DB_CMD -P$DB_PORT -u$DB_USR -p$DB_PASS --all-databases >$DB_BAK/all.sql
    else
        $DB_CMD -P$DB_PORT -u$DB_USR -p$DB_PASS $i >$DB_BAK/${i}.sql
    fi        

    if [ $? -eq 0 ];then
                echo -e "\033[32m----------------------\033[0m" >> $DB_BAK/baksql.log
                echo -e "\033[32mThe $i backup success.\033[0m" >> $DB_BAK/baksql.log
        else
                echo -e "\033[32m---------------------------------\033[0m" >> $DB_BAK/baksql.log
                echo -e "\033[32mThe $i backup failed.please exit.\033[0m" >> $DB_BAK/baksql.log
                exit 2
        fi
done

##压缩
cd /data/backup
tar jcvf `date +%F`.tar.bz2 `date +%F`
if [ $? -eq 0 ];then
    echo -e "\033[32mThe `date +%F` tar success.\033[0m" >> tarsql.log
    rm -rf $DB_BAK
else
    echo -e "\033[32mThe `date +%F` tar failed.\033[0m" >> tarsql.log
fi

##删除N天前的历史备份
find /data/backup/ -maxdepth 1 -type f -name "*.tar.bz2" -mtime +7 -exec rm -f {} \;

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值