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

实例如下: 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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏iOS122-移动混合开发研究院

【树莓派自动化应用实例】整点提醒自己休息五分钟

背景介绍 ? 我有一个习惯,定闹钟每隔60分钟左右,提醒自己休息一次。我发现自己有时候长时间思考,很容易拘泥于细节之中。适当的简单休息过后,往往会对正在解决和处...

27490
来自专栏张善友的专栏

系统进程管理工具Process Explorer

系统进程往往是不少读者操作的“禁区”,其实借助一些功能强大的工具即可消除对该禁区的恐惧。Process Explorer就是一款系统进程管理工具,它不仅能方便地...

27170
来自专栏后台全栈之路

Linux 内核中 Kconfig 文件的作用和添加 menuconfig 项的方法

嵌入式开发中,需要定制或添加一些内核的功能。这里就需要配置 Kconfig 文件了。本文简单说明一下如何修改。便于需要时查找

25850
来自专栏Python中文社区

突破反爬虫的利器——开源IP代理池

专栏作者简介 七 夜 信息安全研究人员,比较擅长网络安全、逆向工程、Python爬虫开发、Python Web开发。 博客园:http://cnblogs.co...

1.2K90
来自专栏Python爬虫与算法进阶

学习Git(一)起步

什么是Git 在Git官网上找到这样一段描述 Git is a free and open source distributed version control...

34760
来自专栏区块链

Cookie窃取与欺骗

Cookie窃取与欺骗 实验准备: 1、xss平台(http://manshow.xyz/xss) 2、黑客:172.18.199.27 3、目标:172.18...

23100
来自专栏喔家ArchiSelf

从连接池到内存池

AI赋能万物,老码农的伙伴们也曾经开发了一个基于图数据库的知识问答系统,在压力测试的时候发现随着并发数的增加,响应的时延明显变长,看时延分布,是应用程序与图数据...

19410
来自专栏互联网研发闲思录

实时监控系统设计

  随着系统业务复杂度的提升,系统复杂度提升,需要对整个系统的功能、性能、可用性,以及服务、 web、webservice、网页等等多个角度进行监控。     ...

92050
来自专栏Albert陈凯

2018-10-14 Chrome 不自动填写密码了 autofill not work

我照着这个里面的方案试验了一次 https://www.v2ex.com/t/255542

13130
来自专栏苦逼的码农

谈谈NAT:什么?全球IP和私有IP是什么鬼?

可能你们会经常听到全球 IP(外网)和私有 IP(内网),他们的区别是什么呢?今天这篇文章来简单讲讲这到底是怎么回事。

19620

扫码关注云+社区

领取腾讯云代金券