使用crontab进行MySQL数据库定时备份和日志清理

使用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博客

你可能感兴趣的:(使用crontab进行MySQL数据库定时备份和日志清理)