linux下配置cron定时执行脚本时,脚本第一行必须明确指定解释程序?

单独执行 python2.7 /x/test.py 一切正常

crontab -l
30 12 * * * python2.7 /x/test.py

cron定时执行脚本时,test.py没有执行
如果在test.py的第一行加上:

#!/usr/local/bin/python2.7

test.py定时正确执行

为什么出现这种情况?

阅读 25.8k
4 个回答

大家都会想到环境变量的问题,可惜没有去读读文档,到底crontab有哪些默认的环境变量。
如果题主你已经在test.py上加入了#!/usr/local/bin/python2.7这一句的话,那么你的crontab定时任务定义只需要:

30 12 * * * /x/test.py

因为脚本第一行指定解释程序后已经是可执行性脚本(文件)了,就不再需要python2.7执行命令了。
如果不修改test.py,也可以给python2.7执行命令指定路径:

30 12 * * * /usr/local/bin/python2.7 /x/test.py

但是什么时候需要指定执行命令的路径呢?还是读读文档吧。
crontab(5) - Linux man page

Several environment variables are set up automatically by the cron(8) daemon. SHELL is set to /bin/sh, and LOGNAME and HOME are set from the /etc/passwd line of the crontab's owner. HOME and SHELL may be overridden by settings in the crontab; LOGNAME may not.

几个环境变量已经自动设置好了的,如当前的SHELL,SHELL=/bin/bash,这个crontab所有者的HOME目录是从/etc/passwd文件中读取的。除了默认的环境变量外,其他环境变量就需要用户自己设置了,为了找到python2.7,就要设置PATH=/user/local/bin了,写法应该是这样的:(没有测试不保证正确)

30 12 * * * PATH=/usr/local/bin python2.7 /x/test.py

或许是cron没有那个$PATH,一般cron里的命令都用完整路径。

你这错误跟我在 rc.local 里犯的一样:/usr/local/bin 不在 $PATH 里。你写在 shebang 里的是绝对路径,但是 crontab 里没写绝对路径。你去看一下 cron 给你发的报错邮件吧(通常默认在 /var/mail 下)。如果你没有安装某个 sendmail 程序就安装一个,不然两眼摸黑地调试 cron 里的程序很难的。

检查是否是用 root 权限设置的 crontab
另建议在crontab里使用完整路径。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏