踩坑记录-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

交流加我或者关我公号

踩坑记录-crontab每10秒执行一次_第5张图片踩坑记录-crontab每10秒执行一次_第6张图片

 

你可能感兴趣的:(linux)