为什么Python脚本可以在CLI中运行,但是从cron作业调用时却不行?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了为什么Python脚本可以在CLI中运行,但是从cron作业调用时却不行?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2152字,纯文字阅读大概需要4分钟。
内容图文
![为什么Python脚本可以在CLI中运行,但是从cron作业调用时却不行?](/upload/InfoBanner/zyjiaocheng/742/9867f9d7d2d340e5b1c06a8d49635d95.jpg)
我创建了一个Python脚本,我想通过Ubuntu服务器上的cronjob每天运行.
这是从命令行运行此脚本的方式:
python /home/username/public_html/IDM_app/manage.py cleanUpPosts
从CLI调用时,脚本运行正常.
但是,当我尝试通过cronjob运行脚本时,脚本无法正常运行.
日志文件显示正在请求脚本,但它们未显示脚本未正确执行的原因.
我在脚本中添加了Python日志记录.从CLI调用脚本时,日志记录正确进行.从cron调用时,python日志记录无法写入其日志文件.
我怀疑问题是cronjob在请求脚本时没有运行shell.
我似乎无法找到cron守护进程记录错误的任何地方.
我创建了/var/log/cron.log
然而,这似乎没有更新.
由于我认为问题源于ENV变量,我试图让cronjob为自己显示ENV.
这是我的crontab的样子:
$crontab -u username -e
m h dom mon dow command
43 17 * * * /bin/sh python /home/username/public_html/IDM_app/manage.py cleanUpPosts
43 17 * * * python /home/username/public_html/IDM_app/manage.py cleanUpPosts
45 21 * * * echo "-----------------"; echo "import os; print os.environ" | python
47 21 * * * /bin/sh echo "------with shell-------"; echo "import os; printos.environ" | python
MAILTO=bryanw@nowhere.com
我以为它会输出到屏幕,但它没有. ENV变量在哪里输出?
无论如何,这里是日志文件:
# tail -n 5 /var/log/*.log
==> /var/log/auth.log <==
Jan 13 17:43:01 servername CRON[7901]: pam_unix(cron:session): session opened for user username by (uid=0)
Jan 13 17:43:01 servername CRON[7902]: pam_unix(cron:session): session opened for user username by (uid=0)
Jan 13 17:44:48 servername su[7909]: Successful su for root by username
Jan 13 17:44:48 servername su[7909]: + /dev/pts/0 username:root
Jan 13 17:44:48 servername su[7909]: pam_unix(su:session): session opened for user root by username(uid=1000)
==> /var/log/bootstrap.log <==
==> /var/log/cron.log <==
==> /var/log/daemon.log <==
==> /var/log/dpkg.log <==
==> /var/log/kern.log <==
==> /var/log/lpr.log <==
==> /var/log/mail.log <==
==> /var/log/mysql.log <==
==> /var/log/pycentral.log <==
==> /var/log/user.log <==
我还应该尝试什么,以便确定我的脚本运行不正常的原因?
解决方法:
crontab可能找不到python可执行文件,虽然它可以在CLI上,所以你需要写下python的完整路径.你得到的相同
which python
Crontab为脚本提供了一个环境,这与普通用户环境不同.
内容总结
以上是互联网集市为您收集整理的为什么Python脚本可以在CLI中运行,但是从cron作业调用时却不行?全部内容,希望文章能够帮你解决为什么Python脚本可以在CLI中运行,但是从cron作业调用时却不行?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。