悲剧的背景

跑自动化脚本的机器连不上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
可惜不知道为什么不生效。

Logo

这里是“一人公司”的成长家园。我们提供从产品曝光、技术变现到法律财税的全栈内容,并连接云服务、办公空间等稀缺资源,助你专注创造,无忧运营。

更多推荐