悲剧的背景
跑自动化脚本的机器连不上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,想说爱你不容易
时间: 2024-12-15 01:47:22