看看MySQL备份脚本的写法

【相关学习推荐:mysql教程

前言:

数据库备份的重要性不言而喻,特别是在生产环境,任何数据的丢失都可能产生严重的后果。所以,无论什么环境,我们都应该有相应的备份策略来定时备份数据库。在 MysqL 中,比较常用的逻辑备份工具是 MysqLdump,本篇文章将介绍 MysqL 定时备份的方法

1.制定合适的备份策略

对于不同的数据库环境,我们应该考虑不同的备份策略。制定备份策略时,应考虑以下几点因素:

  • 物理备份还是逻辑备份。这个可以由数据库大小决定,比如说小于100G用逻辑备份,大于100G用物理备份。
  • 备份文件保留时间。这个可以由磁盘大小决定,一般至少保留7天。
  • 备份执行时间。一般放在业务低峰期,比如凌晨执行备份操作。
  • 备份间隔时间。一般推荐一天一备,如果系统不太重要,备份间隔也可以延长。
  • 是否有从库。有从库的话,推荐放在从库上备份,减小对主库的压力。

2.Linux系统备份脚本

Linux 系统下,我们可以利用 crontab 定时任务来执行备份脚本,如果你你对 crontab 还不了解,可以参考以下介绍快速学习下。

crontab是一个命令,常见于Unix和类Unix的操作系统之中,用于设置周期性被执行的指令。

格式:

* * * * * command
分 时 日 月 周 命令

第1列表示分钟1~59 每分钟用*或者 */1表示
第2列表示小时1~23(0表示0点)
第3列表示日期1~31
第4列表示月份1~12
第5列标识号星期0~6(0表示星期天)
第6列要运行的命令

crontab -e 编辑该用户下的定时任务设置
crontab -l 列出该用户下的所有定时任务

下面我们来正式书写备份脚本,废话不多说,先给出脚本模板:

#!/bin/bash
# -------------------------------------------------------------------------------
# FileName:  MysqL_backup.sh 
# Describe:  Used for database backup
# Revision:  1.0
# Date:    2020/08/11
# Author:   wang

# 设置MysqL登录用户名和密码(根据实际情况填写)
MysqL_user = root
MysqL_password = yourpassword
MysqL_host = localhost
MysqL_port = 3306
backup_dir = /data/MysqL_backup

dt=date +'%Y%m%d_%H%M'
echo Backup Begin Date: $(date +%Y-%m-%d %H:%M:%s)

# 备份全部数据库
MysqLdump -h$MysqL_host -P$MysqL_port -u$MysqL_user -p$MysqL_password -R -E --all-databases --single-transaction > $backup_dir/MysqL_backup_$dt.sql

find $backup_dir -mtime +7 -type f -name '*.sql' -exec rm -rf {} \;
echo Backup Succeed Date: $(date +%Y-%m-%d %H:%M:%s)

以上脚本可根据实际情况修改,比如备份某一个库、保留时间变更等等。脚本写完后要注意调试,调试完成后就可以部署了,比如我们打算每天凌晨2点进行备份,则可以这样设置定时任务。

# 注意脚本执行权限及修改脚本路径
00 02 * * * sh /root/scripts/MysqL_backup.sh > /root/scripts/MysqL_backup.log 2>&1

3.Windows系统备份脚本

Windows 系统备份脚本也是类似的,只不过变成了bat脚本,需要设置计划任务来定时执行。比如我们可以在E盘下创建一个 MysqLdata_Bak 目录,此目录下创建 MysqL_backup 目录存放备份文件MysqL_bak.bat 是备份脚本,脚本内容如下(自动删除7天前的备份文件):

rem auther:wang
rem date:20200811
rem ******MysqL backup start********
@echo off
forfiles /p E:\MysqLdata_Bak\MysqL_backup /m backup_*.sql -d -7 /c cmd /c del /f @path
set Ymd=%date:~0,4%%date:~5,2%%date:~8,2%0%time:~1,1%%time:~3,2%%time:~6,2%
E:\MysqL5.7.23\bin\MysqLdump -uroot -p123456 -P3306 --default-character-set=utf8 -R -E --single-transaction --all-databases > E:\MysqLdata_Bak\MysqL_backup\backup_%Ymd%.sql
@echo on
rem ******MysqL backup end********

以上脚本仅供参考,可以根据自己的环境稍加改动。同样的,脚本调试完成后就可以加入计划任务了,如果你对 Windows 计划任务还不了解,可以百度下,也是比较方便简单的。

4.备份可用性校验

除了备份,非常重要的一件事情就是验证备份数据的可用性。想象一下,当你需要进行数据恢复的时候,忽然发现过去的备份数据都是无效的,那得有多难受。很多朋友在写好备份脚本加到定时任务后,只是检查下定时任务有执行,备份目录有文件就不再关注了,往往到了需要使用备份文件的时候才发现备份数据有问题。

目前对于备份文件的数据校验没有非常方便的办法,用的比较多的还是定时把备份文件拉出来做备份恢复演练,例如一个月做一次备份恢复演练就可以有效提高备份文件可用性,心里也踏实。

所以,千万不要以为有了备份就万无一失了,平时也要多检查备份脚本执行是否正确,生产的备份脚本内容是否可用,最好可以定期做恢复演练。

相关学习推荐:编程视频

相关文章

MySQL 死锁 是指两个或多个事务互相等待对方持有的锁,从而导...
在MySQL中,InnoDB引擎通过Next-Key Locking技术来解决幻读问...
在数据库事务管理中,Undo Log 和 Redo Log 是两种关键日志,...
case when概述 sql语句中的case语句与高级语言中的switch语句...
其实很简单,只是为了忘记,做个记录,用的时候方便。 不管是...
1.进入服务,找到mysql服务,在属性里找到mysql的安装路径 2...