引言
目前工作中需要实现定时备份mysql数据库,这定时执行脚本或者命令可以通过crontabs,crontab储存的指令被守护进程激活, crond常常在后台运行,每一分钟检查是否有预定的作业需要执行。这类作业一般称为cron jobs。
安装crontabs
对于centos使用yum install crontabs命令即可安装crontab,crontab是在unix/linux系统上定时执行某个任务的程序,crontab与crond是有区别的,crond服务是一个定时执行的服务,可以通过crontab 命令添加或者编辑需要定时执行的任务。
查看crond服务状态:service crond status
启动crond服务:service crond start
停止crond服务:service crond stop
修改了配置,重新载入配置:service crond reload
查看crond服务是否已设置为开机启动,执行命令:ntsysv
加入开机自动启动:chkconfig –level 35 crond on
crontab命令
crontab设置计时器,语法:crontab [-u <用户名称>][配置文件] 或 crontab [-u <用户名称>][-elr]。
cron是一个常驻服务,它提供计时器的功能,让用户在特定的时间得以执行预设的指令或程序。只要用户会编辑计时器的配置文件,就可以使 用计时器的功能。参数说明如下所示:
-e 编辑该用户的计时器设置。
-l 列出该用户的计时器设置。
-r 删除该用户的计时器设置。
-u<用户名称> 指定要设定计时器的用户名称。
其配置文件格式如下所示:
* * * * * command
分 时 日 月 周 命令
第1列表示分钟1~59 每分钟用*或者 */1表示
第2列表示小时1~23(0表示0点)
第3列表示日期1~31
第4列 表示月份1~12
第5列标识号星期0~6(0表示星期天)
第6列要运行的命令
# Use the hash sign to prefix a comment
# +—————- minute (0 – 59)
# | +————- hour (0 – 23)
# | | +———- day of month (1 – 31)
# | | | +——- month (1 – 12)
# | | | | +—- day of week (0 – 7) (Sunday=0 or 7)
# | | | | |
# * * * * * command to be executed
具体其他参数可以通过man crontab来查看,这里就不一一详述。
crontab实例
crontab具体实例如下所示:
1.每晚的21:30重启nginx:30 21 * * * /etc/init.d/nginx restart
2.每月1、 10、22日的4 : 45重启nginx:45 4 1,10,22 * * /etc/init.d/nginx restart
3.每一小时重启nginx:* */1 * * * /etc/init.d/nginx restart
4.晚上11点到早上7点之间,每 隔一小时重启nginx:* 23-7/1 * * * /etc/init.d/nginx restart
mysql备份脚本
- #!/bin/sh
-
- DB_USER=root
- DB_PASS=****
- DB_NAME=xxx
- DB_BKPATH="/usr/local/backup"
- DATE=`date +%Y%m%d%H%M`
- HOUR_AGO=`date +%Y%m%d%H -d "-1 hour" `
-
- cd ${DB_BKPATH}
- mysqldump --opt -u${DB_USER} -p${DB_PASS} ${DB_NAME} > ${DB_BKPATH}/${DB_NAME}_${DATE}.sql
- rm -rf ${DB_BKPATH}/${DB_NAME}_${HOUR_AGO}*
要定时执行使用crontab -e来添加定时备份数据库,目前为每6个小时备份一次,具体命令为:
* */6 * * * sh /usr/local/backup/mysql_backup.sh