crontab日常使用梳理

 

在日常的运维工作中,对crontab定时任务的制定是再寻常不过的了。根据以往的使用经验梳理如下:

基本格式 :
*  *  *  *  *  command
分 时  日  月  周  命令
解释:
第1列表示分钟1~59 每分钟用*或者 */1表示
第2列表示小时0~23(0表示0点)
第3列表示日期1~31
第4列表示月份1~12
第5列标识号星期0~6/7(0或7表示星期天)(或用Sun或Mon简写来表示)
第6列要运行的命令

crontab -e 编辑计划任务
crontab -l 查看计划任务
crontab -u username -e 在username用户下编辑计划任务
crontab -u username -l 查看username下的计划任务
crontab -u username -r 删除某个用户的计划任务

所有用户定义的crontab存储在目录/var/spool/cron下(可以在这个目录下直接编辑和删除),任务会以创建者的身份被执行。要以特定用户创建一个crontab,先以该用户登录,执行命令crontab -e(或者在root下执行crontab -u username -e)
crontab的日志是/var/log/cron

实例如下:

0)每15分钟和每30分钟执行一次脚本
00,15,30,45 * * * * /bin/sh /root/autocheck.sh >/dev/null 2>&1
00,30 * * * * /bin/sh /root/testhe.sh >/dev/null 2>&1

1)每一分钟执行/root/monit.sh这个脚本
* * * * * /bin/bash -x /root/monit.sh > /dev/null 2>&1
或者
*/1 * * * * /bin/bash -x /root/monit.sh > /dev/null 2>&1

每n分钟执行一次
*/n * * * * /bin/bash -x /root/monit.sh > /dev/null 2>&1

2)每一小时执行/root/monit.sh这个脚本
10 * * * * /bin/bash -x /root/monit.sh > /dev/null 2>&1
上面的10可以是任何一个数字,其实就是每一小时的第10分钟,或者第n分钟。

每n小时执行一次
n */n * * * /bin/bash -x /root/monit.sh > /dev/null 2>&1

每两小时执行一次
0 */2 * * * /bin/bash -x /root/monit.sh > /dev/null 2>&1

23:00到7:00之间每隔2小时执行一次
0 23-7/2 * * * /bin/bash -x /root/monit.sh > /dev/null 2>&1

23:00到8:00之间每隔1小时执行一次
0 23-8/1 * * * /bin/bash -x /root/monit.sh > /dev/null 2>&1

3)每晚23:59分钟执行
59 23 * * * /bin/bash -x /root/monit.sh > /dev/null 2>&1

即每天的m点的n分钟执行(也即每天执行一次,就是说每天的某个时候去执行就行)
n m * * * /bin/bash -x /root/monit.sh > /dev/null 2>&1

4)晚上11点到早上8点之间每两个小时执行
0 23-8/2 * * * /bin/bash -x /root/monit.sh > /dev/null 2>&1

每天的0点、6点、12点、18点各执行一次
0 0,6,12,18 * * * /bin/bash -x /root/monit.sh > /dev/null 2>&1

11月份内,每天的早上6 点到12 点中,每隔2 小时执行一次
0 6-12/2 * 11 * /bin/bash -x /root/monit.sh > /dev/null 2>&1

5)每个月的4号和每个礼拜的礼拜一到礼拜三的早上11点执行
0 11 4 * 1-3 /bin/bash -x /root/monit.sh > /dev/null 2>&1

或者
0 11 4 * mon-wed /bin/bash -x /root/monit.sh > /dev/null 2>&1

6)1月1日早上4点执行
0 4 1 1 * /bin/bash -x /root/monit.sh > /dev/null 2>&1

7)每周日的4:30执行一次(也即每周执行一次)
30 4 * * 0 /bin/bash -x /root/monit.sh > /dev/null 2>&1

8) 每个月的第一天的6:00执行一次(也即每月执行一次)
0 6 1 * * /bin/bash -x /root/monit.sh > /dev/null 2>&1

9)每月的第1、10、22天的7:30执行一次
30 7 1,10,22 * * /bin/bash -x /root/monit.sh > /dev/null 2>&1

10)每周六、周天的凌晨1:00执行
0 1 * * 6,0 /bin/bash -x /root/monit.sh > /dev/null 2>&1

11)每周一到周五的凌晨2:30执行
30 2 * * 1-5 /bin/bash -x /root/monit.sh > /dev/null 2>&1

12)每天18:00至23:0之间每隔30分钟执行
0,30 18-23 * * * /bin/bash -x /root/monit.sh > /dev/null 2>&1
或者
*/30 18-23 * * * /bin/bash -x /root/monit.sh > /dev/null 2>&1

13)每10秒钟执行一次
* * * * * /bin/bash -x /root/monit.sh > /dev/null 2>&1
* * * * * sleep 10;/bin/bash -x /root/monit.sh > /dev/null 2>&1
* * * * * sleep 20;/bin/bash -x /root/monit.sh > /dev/null 2>&1
* * * * * sleep 30;/bin/bash -x /root/monit.sh > /dev/null 2>&1
* * * * * sleep 40;/bin/bash -x /root/monit.sh > /dev/null 2>&1
* * * * * sleep 50;/bin/bash -x /root/monit.sh > /dev/null 2>&1

每20秒执行一次
* * * * * /bin/bash -x /root/monit.sh > /dev/null 2>&1
* * * * * sleep 20;/bin/bash -x /root/monit.sh > /dev/null 2>&1
* * * * * sleep 40;/bin/bash -x /root/monit.sh > /dev/null 2>&1

每10秒钟执行一次下面的php脚本(log记录)
* * * * * php /home/fdipzone/php/crontab/tolog.php
* * * * * sleep 10;php /home/fdipzone/php/crontab/tolog.php
* * * * * sleep 20;php /home/fdipzone/php/crontab/tolog.php
* * * * * sleep 30;php /home/fdipzone/php/crontab/tolog.php
* * * * * sleep 40;php /home/fdipzone/php/crontab/tolog.php
* * * * * sleep 50;php /home/fdipzone/php/crontab/tolog.php

使用 tail -f 查看执行情况,可以见到log每10秒被写入一条记录。
tail -f /home/fdipzone/php/crontab/run.log
2. 2014-03-31 21:47:01
3. 2014-03-31 21:47:11
4. 2014-03-31 21:47:21
5. 2014-03-31 21:47:31
6. 2014-03-31 21:47:41
7. 2014-03-31 21:47:51
8. 2014-03-31 21:48:01

14) 在root账号下编写crontab -e计划任务,如下分别在6:30,12:30,18:30,23:30时间点,切换到oracle用户下执行脚本(当然也可以直接在oracle账号下编写crontab -e计划任务,如果不生效,就用这种方式)
30 6,12,18,23 * * * su - oracle -c "/bin/bash -x /oradata/script/oracl_data_bak.sh" >/dev/null 2>&1

                                                                                                                                                 
有一台内网服务器,通过squid代理上网。发现在这台内网服务器设定的crontab计划任务无效,没有自动执行!
[root@wang-beta ~]# vim /etc/profile
.....
export HTTP_PROXY=http://192.168.1.199:3128
[root@wang-beta ~]# source /etc/profile

[root@wang-beta ~]# crontab -e
*/28 * * * * /bin/bash /root/sbin/list_update.sh > /dev/null 2>&1

发现上面制定的计划任务,手动执行是生效的。但是crontab自动执行无效。

解决办法:
自动执行无效的原因是没有加载上相关环境变量所致。
执行前,强制添加系统环境变量即可
[root@wang-beta ~]# crontab -e
*/28 * * * * source /etc/profile;/bin/bash /root/sbin/list_update.sh > /dev/null 2>&1
                                                                                                                                          

------------crontal定时执行失败原因总结-----------
1)脚本语法错误
在crontab脚本没有定时执行的时候,首先需要检查脚本的语法有没有出现问题。

2)环境变量问题
有时创建了一个crontab,但是这个任务却无法自动执行,而手动执行这个任务却没有问题,这种情况一般是由于在crontab文件中没有配置环境变量引起的。在手动执行任务时是在
当前shell环境下进行的,程序能够找到环境变量,而系统自动执行任务调度时,是不会加载任何环境变量的。因此,需要在shelll脚本中提供所有必要的路径和环境变量。
需要注意的主要有以下三点:
-> 脚本中涉及文件路径时写全局路径;
-> 脚本执行要用到java或其他环境变量时,通过source命令引入环境变量,如:
   #cat start_cbp.sh
   #!/bin/bash
   source /etc/profile
   export RUN_CONF=/home/work/conf/cbp_jboss.conf
   /usr/local/jboss/bin/run.sh -c mev &

-> 当手动执行脚本OK,但是crontab死活不执行时,这时必须大胆怀疑是环境变量惹的祸,并可以尝试在crontab中直接引入环境变量解决问题。如:
0 * * * * . /etc/profile;/bin/bash -x /home/jira/bin/start_jira.sh

3)系统任务调度及用户任务调度
系统任务调度主要完成系统的一些维护操作,用户任务调度主要完成用户自定义的一些任务,可以将用户任务调度放到系统任务调度来完成(不建议这么做),但是反过来却不行,root
用户的任务调度操作可以通过"crontab –uroot –e"来设置,也可以将调度任务直接写入/etc/crontab文件,需要注意的是,如果要定义一个定时重启系统的任务,就必须将任务放到
/etc/crontab文件,即使在root用户下创建一个定时重启系统的任务也是无效的。

------------crontab定时任务不执行解决办法------------
1)查看crontab执行记录
如果出现了crontab定时任务不执行的情况,首先需要定位问题,那么就需要通过日志来确定问题所在。crontab日志位置一般位于/var/log/cron,利用下面的语句即可查看日志。
# tail -f /var/log/cron
上面的/var/log/cron只会记录是否执行了某些计划的脚本,但是具体执行是否正确以及脚本执行过程中的一些信息linux会通过邮件形式发送到给该用户。
对于root用户该邮件记录位于/var/spool/mail/root,通过以下命令可以查看最近的crontab执行情况。
# tail -f /var/spool/mail/root
mail邮件一般只会记录脚本执行成功与否,如果执行失败,无法给出进一步的错误信息,这时需要我们将语句执行的错误信息重定向至文件中,这样可以很方便的查看错误信息。
下面就给出一个简单的例子:
0 6 * * * /root/script/monit.sh >> /root/for_crontab/mylog.log 2>&1
上述语句表示把错误输出和标准输出都输出到mylog.log中,在执行的时候会将命令执行的相关信息记录至mylog.log文件中。

可以重启crond服务
# /etc/init.d/crond restart

将/var/spool/cron/root文件锁定(chattr +ai /var/spool/cron/root),这样,crontab在root用户下就编辑不了(用户的crontab定时任务执行文件都放在"/var/spool/cron/用户")

crontab服务的启动:
/etc/init.d/crond start/stop/restart/status

posted @ 2016-12-22 18:33  散尽浮华  阅读(2326)  评论(1编辑  收藏  举报