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数据库并删除七天前的备份文件