crontab,想说爱你不容易

悲剧的背景

跑自动化脚本的机器连不上toast服务器了,
只能自己写个脚本每天跑了。
当然要放在crontab里了。
5 3 * * * sh ~/nosecron.sh

更悲剧的结果

第二天过来一看结果,FAIL了大半。

烦燥的分析

很多都是因为:
catch_pkts.append(pkt.getlayer(IP).build())
AttributeError: 'NoneType' object has no attribute 'build'

然后在log的最前面有一句:
WARNING: Failed to execute tcpdump. Check it is installed and in the PATH
手动执行tcpdump, OK
手动执行了nosecron.sh, OK
在nosecron.sh里加了句echo $PATH, 放在crontab里再跑下,居然只有:
/usr/sbin:/usr/bin

快速的解决

在nosecron.sh最前面 加上
export PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin

巧妙的解决

在crontab里:
5 3 * * * su - root -c "sh /root/nosecron.sh"

一劳永逸的解决

在crontab里最前面加上:
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin
可惜不知道为什么不生效。

你可能感兴趣的:(crontab,shell,环境变量)