• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

MySQL数据库定时备份脚本

武飞扬头像
new Object().
帮助1

建议建立备份数据库的用户,本文使用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"
 
#获取系统当前时间并格式化为:20210729
BAK_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}.sql
done
 
#创建压缩文件
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
 fi
done
 
echo "-------$(date  %F_%T) Stop MySQL database backup-------- " >>${BAK_PATH}/back.log
 
学新通

1、查看日志文件:

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-------- 

2、查看备份文件:

ll /opt/mysql_back/

3、解压压缩包查看备份脚本。

tar -zxvf db_backup_20210729.tar.gz

4、确认备份文件没问题后设置定时任务可以实现定时备份:

crontab -e

crontab -e
#每天凌晨3点执行备份,避免影响业务使用,备份时会锁表
 
0 3 * * * sh /root/mysql_back.sh

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhfjijae
系列文章
更多 icon
同类精品
更多 icon
继续加载