整理一下使用crontab 定时备份MySQL数据库。
一、安装crontab
#yum -y install vixie-cron
二、创建备份脚本.sh
//这里是使用mysqldump来导出sql语句并压缩成.gz
mysqldump -uusername -ppassword database > path/name_$(date +%Y%m%d_%H%M%S).sql
mysqldump -uusername -ppassword dababase | gzip > path/name_$(date +%Y%m%d_%H%M%S).sql.gz
//删除sql文件,保留压缩文件即可
find path -name "name_*.sql" -type f -exec rm {} \; > /dev/null 2>&1
//定时删除7天前的备份文件
find path -name "name_*.sql.gz" -type f -mtime +7 -exec rm {} \; > /dev/null 2>&1
username:数据库用户名 eg: root
password:数据库密码; 切记 -uusername -ppassword 之间没有空格
path:你备份MySQL的路径 比如我的就在/home/xxxx里;
database:数据库名称 比如我的就是 test
name:随便是啥名 一般是项目名
然后就是把上面这个脚本语句复制到你的 xxxx.sh 中即可
三、测试运行
测试./xxxx.sh脚本
mysqldump: [Warning] Using a password on the command line interface can be insecure.
mysqldump: [Warning] Using a password on the command line interface can be insecure.
这两句话并不影响我的使用,但是大佬说会导致备份不了 但是我还是备份了。这里我就不管了,备份不了的同学 参见:
你的备份文件夹下出现 xxxx_20190529_164004.sql.gz 表示成功了
四、crontab 定时
crontab -e
跟你vi 是一样的,
0 2 * * * /home/xxxx/xxxx.sh
表示每天凌晨两点备份;
推荐几个实用的
1.每天 02:00 执行任务
0 2 * * * /bin/sh backup.sh
2.每天 5:00和17:00执行任务
0 5,17 * * * /scripts/script.sh
3.每分钟执行一次任务
通常情况下,我们并没有每分钟都需要执行的脚本(默默的想到了12306--)
* * * * * /scripts/script.sh
4.每周日 17:00 执行任务
0 17 * * sun /scripts/script.sh
5.每 10min 执行一次任务
*/10 * * * * /scripts/monitor.sh
6.在特定的某几个月执行任务
* * * jan,may,aug * /script/script.sh
7.在特定的某几天执行任务
0 17 * * sun,fri /script/scripy.sh
在每周五、周日的17点执行任务
8.在某个月的第一个周日执行任务
0 2 * * sun [ $(date +%d) -le 07 ] && /script/script.sh
9.每四个小时执行一个任务
0 */4 * * * /scripts/script.sh
10.每周一、周日执行任务
0 4,17 * * sun,mon /scripts/script.sh
crontab启动命令:
service crond start
service crond stop
service crond restart
service crond reload
以上1-4行分别为启动、停止、重启服务和重新加载配置。
要把cron设为在开机的时候自动启动,在 /etc/rc.d/rc.local 脚本中加入 /sbin/service crond start 即可。
友情提示:你可以搞个一分钟看看效果
/1 * * * * /home/xxxx/xxxx.sh
crontab运行日志
tail -f /var/log/cron
总结:crontab 还是挺好用的,配置还是挺简单的;至于MySQL5.6+以后会报[Warning] Using a password on the command line interface can be insecure. 是否会影响备份,具体情况具体解决,如果可以正常导出sql语句 那么就不用管了吧!