• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    MySQL备份脚本的写法

    前言:

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

    1.制定合适的备份策略

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

    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.备份可用性校验

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

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

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

    总结:

    本篇文章主要分享了 Linux 系统及 Windows 系统下的 MySQL 定时备份脚本,脚本内容比较简单明了,功能并不复杂,如果你有其他备份需求,可以在此基础上修改完善。如果这篇文章对你有所帮助的话,请多多分享转发。

    以上就是MySQL备份脚本的写法的详细内容,更多关于MySQL备份脚本的资料请关注脚本之家其它相关文章!

    您可能感兴趣的文章:
    • 浅析MySQL 备份与恢复
    • 详解mysql的备份与恢复
    • MySQL定时备份方案(利用Linux crontab)
    • 浅析mysql 定时备份任务
    • linux 服务器自动备份脚本的方法(mysql、附件备份)
    • linux定时备份MySQL数据库并删除以前的备份文件(推荐)
    • CentOS7下 MySQL定时自动备份的实现方法
    • Mysql备份多个数据库代码实例
    • MySQL如何优雅的备份账号相关信息
    上一篇:5个MySQL GUI工具推荐,帮助你进行数据库管理
    下一篇:MySQL如何快速导入数据
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    MySQL备份脚本的写法 MySQL,备份,脚本,的,写法,