引言

目前工作中需要实现定时备份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备份脚本

[html] view plain copy

  1. #!/bin/sh  
  2.   
  3. DB_USER=root  
  4. DB_PASS=****  
  5. DB_NAME=xxx  
  6. DB_BKPATH=“/usr/local/backup”  
  7. DATE=`date +%Y%m%d%H%M`  
  8. HOUR_AGO=`date +%Y%m%d%H -d ”-1 hour” `  
  9.   
  10. cd ${DB_BKPATH}  
  11. mysqldump –opt -u${DB_USER} -p${DB_PASS} ${DB_NAME} > ${DB_BKPATH}/${DB_NAME}_${DATE}.sql  
  12. rm -rf ${DB_BKPATH}/${DB_NAME}_${HOUR_AGO}*  

要定时执行使用crontab -e来添加定时备份数据库,目前为每6个小时备份一次,具体命令为:

* */6 * * * sh /usr/local/backup/mysql_backup.sh