CentOS7下如何实现MySQL定时自动备份功能
小编给大家分享一下CentOS7下如何实现MySQL定时自动备份功能,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
我们需要实现下面的几个功能:
第一:数据库备份
第二:数据库通过备份恢复
第三:数据库备份自动化
第四:清理过期备份文件
第一:数据库自动备份
1.创建备份目录
这里我选择了把备份文件放在 /data/backup/mysql下面,把脚本放在 /data/backup 下面:
[root@izwz99z5o9dc90keftqhlrz/]#mkdir-p/data/backup/mysql[root@izwz99z5o9dc90keftqhlrz/]#cd/data/backup
2.创建脚本文件
创建mysql_backup.sh
[root@izwz99z5o9dc90keftqhlrzbackup]#vimysql_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>$filepathecho'导出成功,文件名为:'$filepath
3.新建配置文件
就在我们的当前目录下 即 /data/backup
[root@izwz99z5o9dc90keftqhlrzbackup]#vimy_mysql.cnf[mysqldump]max_allowed_packet=400Mhost=127.0.0.1user=rootpassword='SgDGfsrfEi3#@%#%ugslp%z!dAP'[mysql]host=127.0.0.1user=rootpassword='SgDGfsrfEi3#@%#%ugslp%z!dAP'
各位看官请把上面的参数改成自己的就好了,可别漏了这一步哦
其中 mysqldump 下的参数是给导出的命令使用的,mysql 下的参数是导入的时候使用的
4.给文件权限
到这里的话导出的shell脚本就已经写好了,我们对这个脚本加一下可执行权限
[root@izwz99z5o9dc90keftqhlrzbackup]#chmod+x./mysql_backup.sh
5.执行一下我们的命令
[root@izwz99z5o9dc90keftqhlrzbackup]#sh./mysql_backup.sh#查看一下结果[root@izwz99z5o9dc90keftqhlrzbackup]#ll./mysql
6.扩展使用
我们解压一下已经成功导出的文件,看看原文件大小和压缩后的文件大小对比
[root@izwz99z5o9dc90keftqhlrzbackup]#gzip-dc./mysql/2019-12-22_180359.sql.gz>./mysql/2019-12-22_180359.sql[root@izwz99z5o9dc90keftqhlrzbackup]#ll-sh./mysqltotal44K36K-rw-r--r--1rootroot36KDec2218:062019-12-22_180359.sql8.0K-rw-r--r--1rootroot5.9KDec2218:032019-12-22_180359.sql.gz36Kb和8Kb的对比,如果数据库比较大的话,更能节省空间
到这里为止,我们的导出脚本已经完成了,接下来就是导入脚本了
第二:数据库通过备份恢复
1.创建脚本文件
按照第一步的操作,此时我们应该处于 /data/backup 目录下,继续操作
[root@izwz99z5o9dc90keftqhlrzbackup]#vimysql_restore.sh#!/bin/bashif[-z$1]||[!-f$1]thenecho"请输入sql压缩文件(*.sql.gz)"exit1fi#输入你自己的数据库名称db_name='jx_guides'base_dir='/data/backup/mysql/'gz_sql_file=`basename$1`file_ext=${gz_sql_file##*.}if[$file_ext!='gz']thenecho'文件格式不正确,请输入.sql.gz文件'exit1fisql_file=${gz_sql_file%.*}echo'解压文件中...'gzip-dc$base_dir$gz_sql_file>$base_dir$sql_fileecho'解压完成.'echo'开始导入数据库...'mysql--defaults-extra-file=/data/backup/my_mysql.cnf$db_name<$base_dir$sql_fileif[-f$base_dir$sql_file]thenecho'删除临时文件.'rm-f$base_dir$sql_filefiecho'导入完成.'
上面代码中的配置文件,就是我们第一步时创建的配置文件,在这里一样的使用
2.增加文件可执行权限
[root@izwz99z5o9dc90keftqhlrzbackup]#chmod+x./mysql_restore.sh
3.我们来执行通过备份文件恢复数据库
[root@izwz99z5o9dc90keftqhlrzbackup]#sh./mysql_restore.sh./mysql/2019-12-22_180359.sql.gz
解压文件中...
解压完成.
开始导入数据库...
删除临时文件.
导入完成.
在这里我们的第一个参数可以直接写备份文件的名字,不用写目录,但是因为加上目录之后,可以使用table进行自动补全,所以十分方便,其他的执行方式:其实懂的人知道都一样
其实可以在任何文件夹进行恢复,执行 这个可以在任意位置执行
[root@izwz99z5o9dc90keftqhlrzbackup]#sh/data/backup/mysql_restore.sh/data/backup/mysql/2019-12-22_180359.sql.gz也可以这样[root@izwz99z5o9dc90keftqhlrzmysql]#pwd/data/backup/mysql[root@izwz99z5o9dc90keftqhlrzmysql]#sh/data/backup/mysql_restore.sh2019-12-22_180359.sql.gz
第三:数据库备份自动化
1.添加计划任务
[root@izwz99z5o9dc90keftqhlrzmysql]#crontab-e#粘贴下面的内容,数据库自动备份01,12***/data/backup/mysql_backup.sh#每天凌晨1点,中午12点备份一次数据
第四:清理过期备份文件
1.创建删除文件脚本
[root@izwz99z5o9dc90keftqhlrzmysql]#viremove_backup.sh#/bin/bash#删除15天前的备份find/data/backup/mysql-typef-mtime+15|xargsrm-f
我这里是选择备份数据只保留最近15天的,大家根据需要自行修改
2.添加可执行权限
[root@izwz99z5o9dc90keftqhlrzmysql]#chmod+x./remove_backup.sh#手动删除15天前的备份[root@izwz99z5o9dc90keftqhlrzmysql]#./remove_backup.sh
3.自动清理
[root@izwz99z5o9dc90keftqhlrzmysql]#crontab-e#下面这个就是脚本内容哦,添加这一句01***/data/backup/remove_backup.sh#每天凌晨1点,自动删除15天[15是remove_backup.sh里面配置的]前的备份
第五:定时任务配置给贴出来
#粘贴下面的内容,数据库自动备份01,12***/data/backup/mysql_backup.sh#每天凌晨1点,中午12点备份一次数据#下面这个就是脚本内容哦,添加这一句01***/data/backup/remove_backup.sh#每天凌晨1点,自动删除15天[15是remove_backup.sh里面配置的]前的备份
以上是“CentOS7下如何实现MySQL定时自动备份功能”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。