centos下定时执行脚本或者命令(crontabs备份mysql数据库)

引言

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

猜你喜欢

转载自blog.csdn.net/qq_33468857/article/details/81836377