踩坑记录之crontab每10秒执行一次问题

crontab每10秒执行一次问题

需求:linux中使用crontab每十秒执行一次

场景:需要在ubuntu14服务器中使用代理每十秒执行一次curl来访问互联网,来测试代理网络稳定性。

经过网上的大量搜贴之后得到的可用的一个结论如下:

# crontab -e
* * * * * /usr/local/cc.sh >>/usr/local/log.txt 2>&1
* * * * * sleep 10; /usr/local/cc.sh >>/usr/local/log.txt 2>&1
* * * * * sleep 20; /usr/local/cc.sh >>/usr/local/log.txt 2>&1
* * * * * sleep 30; /usr/local/cc.sh >>/usr/local/log.txt 2>&1
* * * * * sleep 40; /usr/local/cc.sh >>/usr/local/log.txt 2>&1
* * * * * sleep 50; /usr/local/cc.sh >>/usr/local/log.txt 2>&1

如果你是直接一梭子全复制,改下目录那么恭喜你完成了计划任务。而我就不是了,我只写了sleep 10 这条然后任务没有执行。这就是坑。

坑1 .上面sleep 10 20 30 ...是啥意思啊,怎么个规则啊。一头雾水,当时我是直接把第二个sleep 10 那个定时任务直接粘进去的。然后,任务没有执行就一直纠结任务没有执行这个问题。

坑2.ubuntu系统第一次使用crontab -e 需要选择比编辑器,如果选nano上,对我这种小白可就蒙圈。最后在命令行使用, select-ediort 来选择编辑器选3 vim 就好了

后来,明白后做了实验。

如果只写前两条的话是:在每分钟的第一秒和第一个10秒执行一次

 * * * * * /usr/local/cc.sh >>/usr/local/log.txt 2>&1
 * * * * * sleep 10; /usr/local/cc.sh >>/usr/local/log.txt 2>&1

踩坑记录之crontab每10秒执行一次问题_第1张图片

踩坑记录之crontab每10秒执行一次问题_第2张图片

以此类推只写前三的话就是:

在每分钟的第一、第一个十秒、第二个十秒分别执行一次

* * * * * /usr/local/cc.sh >>/usr/local/log.txt 2>&1
* * * * * sleep 10; /usr/local/cc.sh >>/usr/local/log.txt 2>&1
* * * * * sleep 20; /usr/local/cc.sh >>/usr/local/log.txt 2>&1

如果都写上的话就是每十秒执行一次啦,完美过程

踩坑记录之crontab每10秒执行一次问题_第3张图片

过程遇到的问题(1):crontab -e 完都有新邮件

原因:

1.crontab 每次执行完程序产生的输出都会发邮件到/var/mail/root

2.定时任务语法有误,/var/mail/root  发送的是错误日志,如下

root@bogon:/usr/local# tail -20 /var/mail/root  

From root@bogon Tue May 21 18:31:11 2019Return-Path: X-Original-To: rootDelivered-To: root@bogonReceived: by bogon (Postfix, from userid 0) id AAFCB43077; Tue, 21 May 2019 18:31:11 +0800 (CST)From: root@bogon (Cron Daemon)To: root@bogonSubject: Cron sleep 10; sh /home/liuxin/curl-status.sh >dev/null 2>&1Content-Type: text/plain; charset=ANSI_X3.4-1968X-Cron-Env: X-Cron-Env: X-Cron-Env: X-Cron-Env: Message-Id: <20190521103111.AAFCB43077@bogon>Date: Tue, 21 May 2019 18:31:11 +0800 (CST) /bin/sh: 1: cannot create dev/null: Directory nonexistent

解决:

如果是1的话就放到黑洞  >/dev/null 2>&1

* * * * * /usr/local/cc.sh >/dev/null 2>&1

精讲:

1,/dev/null是linux系统的一个垃圾桶(一个不正经的比喻)有不用的输出都可以往里面扔。>/dev/null 缺省默认是1 即 1>/dev/null    

2,linux中有三种标准输入输出,分别是STDIN,STDOUT,STDERR,对应的数字是0,1,2    2>&1就是把2错误输出重定向到1标准输出  而1又输出到/dev/null黑洞

如果不想输出到一个文件可以这样写

* * * * * /usr/local/cc.sh >>/usr/local/log.txt 2>&1

过程中遇到的问题(2):如图crontab -e 后是新文件

踩坑记录之crontab每10秒执行一次问题_第4张图片

解决:crontab语法错误再三检查后,建议select-editor 选3  vim

linux crontab使用技巧

crontab命令主要用于设置命令行或者脚本周期性的执行。该命令从标准输入设备读取指令,并将其存放于文件中,以供之后读取和执行。

主要讲述crontb命令的基本语法和配置方法。

crontab命令格式

crontab [-u user] -e -l -r
  • -u 用户名,不加-u参数默认为当前用户。
  • -e 编辑crontab文件。
  • -l 列出crontab文件中的内容。取值来源为/var/spool/cron下对应的文件
  • -r 删除crontab文件。

crontab命令格式

# Example of job definition:
 .---------------- minute (0 - 59)
 |  .------------- hour (0 - 23)
 |  |  .---------- day of month (1 - 31)
 |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
 |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
 |  |  |  |  |
 *  *  *  *  * command/script

一个定时任务的配置共包括6个字段,分别是分、时、日、月、周、命令行或脚本,每一列取值的范围或者含义如上述格式中注释描述。

特别注意一点是命令行或者脚本一定要配置成绝对路径。

特殊字段说明

  • 星号(*):代表所有可能的值,例如在第1列表示每分钟执行,第2列表示每小时执行,第3列表示每天执行。
  • 逗号(,):可以用逗号隔开的值表示指定一个列表范围,例如,在第1列设置15,30,45表示在第15分钟、30分钟、45分钟执行。
  • 中杠(-):可以用整数之间的中杠表示一个整数范围,例如"2-6"表示2,3,4,5,6
  • 正斜线(/):可以用正斜线指定时间的间隔频率,例如第2列设置成"*/2",表示每两小时执行一次。

每天晚上10点运行rumenz.sh脚本

0 22 * * * /root/rumenz.sh

每月的1,3,7的早上8.30运行rumenz.sh

> 30 8 1,3,7 * * /root/rumenz.sh

每周六,日的的凌晨2点执行rumenz.sh

> 0 2 * * 6,0 /root/rumenz.txt

每天的的18点到23点每30分执行rumenz.sh

0,30 18-23 * * /root/rumenz.sh

//或者

*/30 18-23 * * /root/rumenz.sh

每天凌晨2点访问一个网址

> 0 2 * * * /usr/bin/curl https://rumenz.com

crontab每10秒执行一次rumenz.sh

* * * * * /root/rumenz.sh
* * * * * sleep 10;/root/rumenz.sh
* * * * * sleep 20;/root/rumenz.sh
* * * * * sleep 30;/root/rumenz.sh
* * * * * sleep 40;/root/rumenz.sh
* * * * * sleep 50;/root/rumenz.sh

每 90 分钟运行一次rumenz.sh

0 0-21/3 * * * /root/rumenz.sh
30 0-22/3 * * * /root/rumenz.sh

需要两个表达式实现

每90秒执行一次rumenz.sh

*/3 * * * * /root/rumenz.sh
*/3 * * * * sleep 90;/root/rumenz.sh

需要两个表达式实现

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

你可能感兴趣的:(踩坑记录之crontab每10秒执行一次问题)