建议建立备份数据库的用户,本文使用root用户进行备份。
脚本内容如下:
vim mysql_back.sh
#!/bin/bash #指定连接数据库信息(用户名、密码、连接地址、端口、安装目录)DB_USER="root"DB_PWD="password"DB_IP="host"DB_PORT="3306"#是指mysqldump命令所在目录DB_DIR="/usr/local/mysql" #获取系统当前时间并格式化为:20210729BAK_DATE=`date +%Y%m%d` #指定备份文件保存的天数BAK_DAY=7#指定备份的数据库,可以指定多个中间用空格隔开,或者不指定则默认全部备份BAK_DATABASES=("")#指定备份路径BAK_PATH="/data/mysql_back" #创建备份目录mkdir ${BAK_PATH}/$BAK_DATE #开始执行备份echo "------- $(date +%F_%T) Start MySQL database backup-------- " >>${BAK_PATH}/back.log#循环遍历for database in "${BAK_DATABASES[@]}"do ${DB_DIR}/bin/mysqldump -u${DB_USER} -p${DB_PWD} --host=${DB_IP} --port=${DB_PORT} --databases $database > ${BAK_PATH}/${BAK_DATE}/${database}.sqldone #创建压缩文件cd ${BAK_PATH}tar -zcPf db_backup_${BAK_DATE}.tar.gz $BAK_DATE #删除备份目录mv ${BAK_PATH}/$BAK_DATE /tmp1 #遍历备份目录下的文件LIST=$(ls ${BAK_PATH}/db_backup_*) #获取截止时间,将早于改时间的文件删除 SECONDS=$(date -d "$(date +%F) - ${BAK_DAY} days" +%s) for index in ${LIST}do #获取文件名并格式化,获取时间,如20210729 timeString=$(echo ${index} | egrep -o "?[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]") if [ -n "$timeString" ] then indexDate=${timeString//./-} indexSecond=$( date -d ${indexDate} +%s ) #与当前时间做比较,把早于7天的文件删除 if [ $(( $SECOND - $indexDate )) -gt 0 ] then rm -f $index echo "-------deleted old file $index -------" >> ${BAK_PATH}/back.log fi fidone echo "-------$(date +%F_%T) Stop MySQL database backup-------- " >>${BAK_PATH}/back.log
查看日志文件:
cat /opt/mysql_back/back.log
cat /opt/mysql_back/back.log ------- 2021-07-29_18:25:09 Start MySQL database backup-------- -------2021-07-29_18:25:09 Stop MySQL database backup--------
查看备份文件:
ll /opt/mysql_back/
解压压缩包查看备份脚本。
tar -zxvf db_backup_20210729.tar.gz
确认备份文件没问题后设置定时任务可以实现定时备份:
crontab -e
crontab -e#每天凌晨3点执行备份,避免影响业务使用,备份时会锁表 0 3 * * * sh /root/mysql_back.sh
来源地址:https://blog.csdn.net/weixin_45100257/article/details/128476102