#!/bin/bash
. /etc/profile
#. ~/.bash_profile
#备份路径
BACKUP=/mnt/mysql_bak
#当前时间
DATETIME=$(date +%Y-%m-%d)
#DATETIME=$(date +%Y-%m-%d-%H-%M-%S)
echo "===备份开始==="
echo "备份文件存放于${BACKUP}/$DATETIME"
#数据库地址
HOST=xxx.xxx.xxx.xxx
#数据库用户名
DB_USER=root
#数据库密码
DB_PW=xxxxxx
#创建备份目录
[ ! -d "${BACKUP}/$DATETIME" ] && mkdir -p "${BACKUP}/$DATETIME"
#后台系统数据库
all=' xxx xxx xxx xxx '
for DATABASE in $all
do
echo $DATABASE-$DATETIME
#直接导出zip压缩文件,其中dump的文件不为sql格式
#mysqldump -u${DB_USER} -p${DB_PW} --single-transaction --host=$HOST -q -R --databases $DATABASE | gzip > ${BACKUP}/$DATETIME/$DATABASE.zip
#导出sql文件,后续需要压缩
mysqldump -h xxx.xxx.xxx.xxx -u${DB_USER} -p${DB_PW} ${DATABASE} >${BACKUP}/$DATETIME/$DATABASE-$DATETIME.sql
echo "===导出成功,开始压缩==="
#压缩成tar.gz包
cd $BACKUP/$DATETIME/
tar -zcvf $DATABASE-$DATETIME.tar.gz $DATABASE-$DATETIME.sql
#备份到服务器B
#sshpass -p 密码 scp $DATABASE-$DATETIME.sql 用户名@10.3.242.47:/另一台服务器的备份目录/
#删除备份文件
rm -rf ${BACKUP}/$DATETIME/$DATABASE-$DATETIME.sql
done
#删除1天前备份的数据,可以自行更改
find $BACKUP -mtime +1 -name "2021*" -exec rm -rf {} \;
echo "===数据库备份到服务器成功==="
xxx为变量根据实际情况替换
存在问题:
备份没有循环机制,备份完成一个库之后会接着压缩、删除原文件,本脚本无法做到把所有的库备份完成之后统一压缩并删除,后续还需改进
配置定时任务
crontab -e