1.先写好mysql备份执行文件

#创建备份文件夹,集中管理备份
mkdir /bak
cd /bak
#创建mysql文件夹
mkdir mysqldata
cd mysqldata
vim Mysqlbackup.sh

#!/bin/bash
# Name:mysqlbackup.sh
# This is a Shell For Auto DB Backup and Delete old Backup
# 备份路径
backupdir=/bak/mysqlbackup
time=` date +%Y%m%d%H `
/opt/mysql/bin/mysqldump -uroot --password=123456 -P3307 dataname | gzip > $backupdir/dataname_$time.sql.gz
/opt/mysql/bin/mysqldump -uroot --password=123456 -P3307 dataname1 | gzip > $backupdir/dataname_1$time.sql.gz
#删除七天前的备份
find $backupdir -name "dataname_*.sql.gz" -type f -mtime +7 -exec rm {} ; > /dev/null 2>&1
#
#

编写完 :wq保存 也可以使用我写好的。下载下来改一改参数

curl -o  https://github.com/76peter/LearnShell/blob/master/Mysqlbackup.sh

说明:

代码中 time=date +%Y%m%d%H也可以写为time=”$(date +”%Y%m%d$H”)” 其中`符号是TAB键上面、ESC下面的符号,不是ENTER左边的’符号,date后要有一个空格。 dataname:数据库名; root:数据库用户名; password:用户密码; dataname_:自定义备份文件前缀标识。 -type f 表示查找普通类型的文件,f表示普通文件。 -mtime +7 按照文件的更改时间来查找文件,+7表示文件更改时间距现在7天以前;如果是 -mmin +7 表示文件更改时间距现在7分钟以前。 -exec rm {} ; 表示执行一段shell命令,exec选项后面跟随着所要执行的命令或脚本,然后是一对儿{},一个空格和一个,最后是一个分号。 /dev/null 2>&1 把标准出错重定向到标准输出,然后扔到/DEV/NULL下面去。通俗的说,就是把所有标准输出和标准出错都扔到垃圾桶里面;其中的&表示让该命令在后台执行。

2.授权并执行测试

chmod 777 Mysqlbackup.sh  
#或者 
chmod +x Mysqlbackup.sh
#执行看看效果 是否生成文件了, 可以加上输出日志查看是否报错
./Mysqlbackup.sh >run.log 2>&1

3.Centos7:利用crontab定时执行任务

其他版本linux可以自行查找定时任务处理办法😄

systemctl start crond 
#编辑任务
crontab -e
# 加入一行,表示每天3点00分执行备份
00 3 * * * /bak/mysqldata/Mysqlbackup.sh
#保存并退出:wq

#还原备份
gzip < dataname_2011070103.sql.gz | mysql -u root --password=123456 -p3307 dataname

cron服务是Linux的内置服务,但它不会开机自动启动。可以用以下命令启动和停止服务:

systemctl start crond

systemctl stop crond

systemctl restart crond

systemctl reload crond

以上1-4行分别为启动、停止、重启服务和重新加载配置。

要把cron设为在开机的时候自动启动,在 /etc/rc.d/rc.local 脚本中加入 /sbin/service crond start 即可

查看当前用户的crontab,输入 crontab -l -u root #查看root用户;

编辑crontab,输入 crontab -e;

删除crontab,输入 crontab -r


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

crontab文件的一些例子:
30 21 * * * /usr/local/etc/rc.d/lighttpd restart
上面的例子表示每晚的21:30重启apache。
45 4 1,10,22 * * /usr/local/etc/rc.d/lighttpd restart
上面的例子表示每月1、10、22日的4 : 45重启apache。
10 1 * * 6,0 /usr/local/etc/rc.d/lighttpd restart
上面的例子表示每周六、周日的1 : 10重启apache。
0,30 18-23 * * * /usr/local/etc/rc.d/lighttpd restart
上面的例子表示在每天18 : 00至23 : 00之间每隔30分钟重启apache。
0 23 * * 6 /usr/local/etc/rc.d/lighttpd restart
上面的例子表示每星期六的11 : 00 pm重启apache。
* */1 * * * /usr/local/etc/rc.d/lighttpd restart
每一小时重启apache
* 23-7/1 * * * /usr/local/etc/rc.d/lighttpd restart
晚上11点到早上7点之间,每隔一小时重启apache
0 11 4 * mon-wed /usr/local/etc/rc.d/lighttpd restart
每月的4号与每周一到周三的11点重启apache
0 4 1 jan * /usr/local/etc/rc.d/lighttpd restart
一月一号的4点重启apache

日志查看 看 /var/log/cron这个文件就可以,可以用tail -f /var/log/cron观察

致谢

文章参考来源: Centos7:利用crontab定时执行任务 linux定时备份MySQL数据库并删除七天前的备份文件