美文网首页
CentOS7 MySQL定时自动备份实现 --- 2019-1

CentOS7 MySQL定时自动备份实现 --- 2019-1

作者: 一位先生_ | 来源:发表于2019-12-24 10:48 被阅读0次

    生产环境遇到得最幸福得事情就是,某些场景没办法避免去update或者delete的时候,某个参数没有注意。完蛋了 完蛋了,数据被我搞崩了怎么办,赶紧去运营找备份呀!运营说:狗屁 咱们系统从来不备份,你说:那把日志给我吧,运营说:狗屁 每天上G的日志,我都没给你开,你说:怎么办,数据库被我搞崩了。运营说:那是你的事,跟我没关系........这是某公司的一段写照,所以今天我们来把这个情况给杜绝

    今天要给客户部署一套系统,使用的MySQL5.7,那客户那边的开发人员我可不敢保证他们的能力咋样。我只能给他们全部开机自启、数据库等重要文件自动备份好,一旦出什么幺蛾子。咱风淡云轻的一行命令给搞定,这是一个负责任的做法。准备开始:

    我们需要实现下面的几个功能:

    第一:数据库备份

    第二:数据库通过备份恢复

    第三:数据库备份自动化

    第四:清理过期备份文件

    第一:数据库自动备份
    1.创建备份目录

    这里我选择了把备份文件放在 /data/backup/mysql下面,把脚本放在 /data/backup 下面:

    [root@izwz99z5o9dc90keftqhlrz /]# mkdir -p /data/backup/mysql
    [root@izwz99z5o9dc90keftqhlrz /]# cd /data/backup
    

    2.创建脚本文件

    创建mysql_backup.sh

    [root@izwz99z5o9dc90keftqhlrz backup]# vi mysql_backup.sh
    
    #!/bin/bash
    # db_name 自己改这里哦
    db_name='baizhan'
    backup_dir='/data/backup/mysql/'
    current_time=$(date +'%Y-%m-%d_%H%M%S')
    filepath=$backup_dir$current_time'.sql.gz'
    #此处没有使用 $db_password $db_user, 已经写入到配置文件中
    echo '开始导出数据库...'
    mysqldump --defaults-extra-file=/data/backup/my_mysql.cnf  $db_name | gzip > $filepath
    echo '导出成功,文件名为: '$filepath
    

    3.新建配置文件

    就在我们的当前目录下 即 /data/backup

    [root@izwz99z5o9dc90keftqhlrz backup]# vi my_mysql.cnf
    
    [mysqldump]
    max_allowed_packet = 400M
    host=127.0.0.1
    user=root
    password='SgDGfsrfEi3#@%#%ugslp%z!dAP'
    [mysql]
    host=127.0.0.1
    user=root
    password='SgDGfsrfEi3#@%#%ugslp%z!dAP'
    

    各位看官请把上面的参数改成自己的就好了,可别漏了这一步哦
    其中 mysqldump 下的参数是给导出的命令使用的,mysql 下的参数是导入的时候使用的

    4.给文件权限

    到这里的话导出的shell脚本就已经写好了,我们对这个脚本加一下可执行权限

    [root@izwz99z5o9dc90keftqhlrz backup]# chmod +x ./mysql_backup.sh
    

    5.执行一下我们的命令

    [root@izwz99z5o9dc90keftqhlrz backup]# sh ./mysql_backup.sh
    

    查看一下结果

    [root@izwz99z5o9dc90keftqhlrz backup]# ll ./mysql
    
    20191222180449755.png

    6.扩展使用

    我们解压一下已经成功导出的文件,看看原文件大小和压缩后的文件大小对比

    [root@izwz99z5o9dc90keftqhlrz backup]# gzip -dc ./mysql/2019-12-22_180359.sql.gz > ./mysql/2019-12-22_180359.sql
    
    [root@izwz99z5o9dc90keftqhlrz backup]# ll -sh ./mysql
    total 44K
     36K -rw-r--r-- 1 root root  36K Dec 22 18:06 2019-12-22_180359.sql
    8.0K -rw-r--r-- 1 root root 5.9K Dec 22 18:03 2019-12-22_180359.sql.gz
    

    36Kb 和8Kb的对比,如果数据库比较大的话,更能节省空间
    到这里为止,我们的导出脚本已经完成了,接下来就是导入脚本了

    第二:数据库通过备份恢复
    1.创建脚本文件

    按照第一步的操作,此时我们应该处于 /data/backup 目录下,继续操作

    [root@izwz99z5o9dc90keftqhlrz backup]#  vi mysql_restore.sh
    
     
    #!/bin/bash
    if [ -z $1 ] || [ ! -f $1 ]
    then
        echo "请输入sql压缩文件(*.sql.gz)"
        exit 1
    fi
    #输入你自己的数据库名称
    db_name='jx_guides'
    base_dir='/data/backup/mysql/'
    gz_sql_file=`basename $1`
     
    file_ext=${gz_sql_file##*.}
    if [ $file_ext != 'gz' ]
    then
        echo '文件格式不正确,请输入 .sql.gz 文件'
        exit 1
    fi
     
    sql_file=${gz_sql_file%.*}
    echo '解压文件中...'
    gzip -dc $base_dir$gz_sql_file > $base_dir$sql_file
    echo '解压完成.'
    echo '开始导入数据库...'
     
    mysql --defaults-extra-file=/data/backup/my_mysql.cnf $db_name < $base_dir$sql_file
     
    if [ -f $base_dir$sql_file ]
    then
        echo '删除临时文件.'
        rm -f $base_dir$sql_file
    fi
    echo '导入完成.'
    

    上面代码中的配置文件,就是我们第一步时创建的配置文件,在这里一样的使用

    2.增加文件可执行权限

    [root@izwz99z5o9dc90keftqhlrz backup]# chmod +x ./mysql_restore.sh
    

    3.我们来执行通过备份文件恢复数据库

    [root@izwz99z5o9dc90keftqhlrz backup]# sh ./mysql_restore.sh ./mysql/2019-12-22_180359.sql.gz
    

    解压文件中...
    解压完成.
    开始导入数据库...
    删除临时文件.
    导入完成.
    在这里我们的第一个参数可以直接写备份文件的名字,不用写目录,但是因为加上目录之后,可以使用table进行自动补全,所以十分方便,其他的执行方式:其实懂的人知道都一样

    其实可以在任何文件夹进行恢复,执行 这个可以在任意位置执行

    [root@izwz99z5o9dc90keftqhlrz backup]# sh /data/backup/mysql_restore.sh /data/backup/mysql/2019-12-22_180359.sql.gz
    

    也可以这样

    [root@izwz99z5o9dc90keftqhlrz mysql]# pwd
    /data/backup/mysql
    [root@izwz99z5o9dc90keftqhlrz mysql]# sh /data/backup/mysql_restore.sh 2019-12-22_180359.sql.gz
    

    第三:数据库备份自动化
    1.添加计划任务

    [root@izwz99z5o9dc90keftqhlrz mysql]# crontab -e
    

    粘贴下面的内容, 数据库自动备份

    0 1,12 * * * /data/backup/mysql_backup.sh # 每天凌晨1点,中午12点备份一次数据
    

    第四:清理过期备份文件
    1.创建删除文件脚本

    [root@izwz99z5o9dc90keftqhlrz mysql]# vi remove_backup.sh
    
    #/bin/bash 
    # 删除15天前的备份
    find /data/backup/mysql -type f -mtime +15 | xargs rm -f
    

    我这里是选择备份数据只保留最近15天的,大家根据需要自行修改
    2.添加可执行权限

    [root@izwz99z5o9dc90keftqhlrz mysql]# chmod +x ./remove_backup.sh
    #手动删除 15天前的备份
    [root@izwz99z5o9dc90keftqhlrz mysql]# ./remove_backup.sh
    

    3.自动清理

    [root@izwz99z5o9dc90keftqhlrz mysql]# crontab -e
    

    下面这个就是脚本内容哦,添加这一句

    0 1 * * * /data/backup/remove_backup.sh # 每天凌晨1点,自动删除15天[15是remove_backup.sh里面配置的]前的备份
    

    第五:定时任务配置给贴出来

    粘贴下面的内容, 数据库自动备份

    0 1,12 * * * /data/backup/mysql_backup.sh # 每天凌晨1点,中午12点备份一次数据
    

    下面这个就是脚本内容哦,添加这一句

    0 1 * * * /data/backup/remove_backup.sh # 每天凌晨1点,自动删除15天[15是remove_backup.sh里面配置的]前的备份
    

    相关文章

      网友评论

          本文标题:CentOS7 MySQL定时自动备份实现 --- 2019-1

          本文链接:https://www.haomeiwen.com/subject/lemxoctx.html