前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >踩坑记录-crontab每10秒执行一次

踩坑记录-crontab每10秒执行一次

作者头像
学一学大数据
发布2019-05-30 14:55:12
6.1K0
发布2019-05-30 14:55:12
举报
文章被收录于专栏:学一学大数据学一学大数据

写在前面,记录一个linux小白使用crontab中遇到的各种坑及解决思路方法。网上帖子千千万,坑也是千千万。记录下,分享给大家。

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

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

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

代码语言:javascript
复制
# 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秒执行一次

代码语言:javascript
复制
* * * * * /usr/local/cc.sh >>/usr/local/log.txt 2>&1* * * * * sleep 10; /usr/local/cc.sh >>/usr/local/log.txt 2>&1

以此类推只写前三的话就是:在每分钟的第一、第一个十秒、第二个十秒分别执行一次

代码语言:javascript
复制
* * * * * /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

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

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

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

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

代码语言:javascript
复制
root@bogon:/usr/local# tail -20 /var/mail/rootFrom root@bogon  Tue May 21 18:31:11 2019Return-Path: <root@bogon>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 <root@bogon> sleep 10; sh /home/liuxin/curl-status.sh >dev/null 2>&1Content-Type: text/plain; charset=ANSI_X3.4-1968X-Cron-Env: <SHELL=/bin/sh>X-Cron-Env: <HOME=/root>X-Cron-Env: <PATH=/usr/bin:/bin>X-Cron-Env: <LOGNAME=root>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

代码语言:javascript
复制
* * * * * /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黑洞

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

代码语言:javascript
复制
* * * * * /usr/local/cc.sh >>/usr/local/log.txt 2>&1

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

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

转发是最大的支持。评论区等你!

SHOWTIME

想要加入我们IT资源社群吗?想要与志同道合的小伙伴们一起成长和发展吗?想要及时获得各种技术福利吗?

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-05-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 学一学大数据 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档