使用crontab进行MySQL数据库的定时备份和清理
Linux crontab 是用来定期执行程序的命令。
当安装完成操作系统之后,默认便会启动此任务调度命令。
crond 命令每分钟会定期检查是否有要执行的工作,如果有要执行的工作便会自动执行该工作。
注意:新创建的 cron 任务,不会马上执行,至少要过 2 分钟后才可以,当然你可以重启 cron 来马上执行。
而 linux 任务调度的工作主要分为以下两类:
1、系统执行的工作:系统周期性所要执行的工作,如备份系统数据、清理缓存
2、个人执行的工作:某个用户定期要做的工作,例如每隔 10 分钟检查邮件服务器是否有新信,这些工作可由每个用户自行设置
下面进入案例:
需求一:对数据库进行定时备份
需求二:对日志文件进行定时清理
1.创建脚本所在目录:此处放在/laj下 ,并创建备份数据库所在的目录:/laj/backup_sql/db
2.进入新建的/laj/下的脚本文件里,这里是 vim mysql_db_backup.sh,编写如下文件信息:
①数据库定时备份
BACKUP=/laj/backup_sql/db
#当前时间
DATETIME=$(date +%y-%m-%d_%H%M%S)
echo $DATETIME
#数据库地址
HOST=xxx.xxx.xxx.xxx
#数据库用户名
DB_USER=dbuser
#数据库密码
DB_PW=dbpasswd
#备份的数据库名
DATABASE=databaseName
#创建备份目录如果不存在,就创建
[ ! -d "${BACKUP}/${DATETIME}" ] && mkdir -p "${BACKUP}/${DATETIME}"
#备份数据库
mysqldump -u${DB_USER} -p${DB_PW} --host=${HOST} -q -R --databases ${DATABASE} | gzip > ${BACKUP}/${DATETIME}/$DATETIME.sql.gz
#将文件处理成tar.gz
cd ${BACKUP}
tar -zcvf $DATETIME.tar.gz ${DATETIME}
#删除对应的备份目录
rm -rf ${BACKUP}/${DATETIME}
②对laj目录下nohup文件定时清理
同上vim log_clean.sh (此任务只定时清理nohup.out日志)
#清理日志文件
echo '' > /laj/nohup.out
3.给所有者增加执行权限
chmod u+x mysql_db_backup.sh
chmod u+x log_clean.sh
4.编写crontab定时任务
crontab -e #对任务进行定时
#每周二15:10进行数据库备份
10 15 * * 2 /mysql_db_backup.sh
#每周二15:00进行日志清理
0 15 * * 2 /log_clean.sh
5.重启crontab服务
/bin/systemctl stop crond.service
/bin/systemctl start crond.service
ending……
Linux crontab常用定时命令:
参数说明:每一个* 代表分别是:
* * * * *
- - - - -
| | | | |
| | | | +----- 星期中星期几 (0 - 6) (星期天 为0)
| | | +---------- 月份 (1 - 12)
| | +--------------- 一个月中的第几天 (1 - 31)
| +-------------------- 小时 (0 - 23)
+------------------------- 分钟 (0 - 59)
每一分钟执行一次 /bin/ls:
* * * * * /bin/ls
下面再看看几个具体的例子:
0 */2 * * * /sbin/service httpd restart 意思是每两个小时重启一次apache
50 7 * * * /sbin/service sshd start 意思是每天7:50开启ssh服务
50 22 * * * /sbin/service sshd stop 意思是每天22:50关闭ssh服务
0 0 1,15 * * fsck /home 每月1号和15号检查/home 磁盘
1 * * * * /home/bruce/backup 每小时的第一分执行 /home/bruce/backup这个文件
00 03 * * 1-5 find /home "*.xxx" -mtime +4 -exec rm {} \; 每周一至周五3点钟,在目录/home中,查找文件名为*.xxx的文件,并删除4天前的文件。
30 6 */10 * * ls 意思是每月的1、11、21、31日是的6:30执行一次ls命令
删除crontab定时任务
使用shell脚本或命令行添加、删除 crontab 定时任务_墨痕诉清风的博客-CSDN博客_crontab 删除任务
crontab -r 即删除所有定时任务
小结:
① vim编写.sh可执行文件脚本
② 给所有者增加执行权限 chmod u+x mysql_db_backup.sh
③ 新增crontab定时任务后开启任务:
crontab -e
④ 编辑定时任务并写入以下内容
#每周二15:10进行数据库备份
10 15 * * 2 /mysql_db_backup.sh
#每周二15:00进行日志清理
0 15 * * 2 /log_clean.sh
⑤ 重启crontab服务(在每次新增定时任务之后需要重启)
/bin/systemctl stop crond.service
/bin/systemctl start crond.service
⑥查看所有当前正在运行的定时任务
crontab -l
扩展:
Linux - 如何定时清空tomcat的catalina.out日志文件.( 释放磁盘空间 )_Xiao·Jian的博客-CSDN博客