gpt4 book ai didi

python - 为什么 Python 脚本在 CLI 中运行,但在从 cron 作业调用时却不行?

转载 作者:太空宇宙 更新时间:2023-11-03 13:23:50 24 4
gpt4 key购买 nike

我创建了一个 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 用户名 -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 - 为什么 Python 脚本在 CLI 中运行,但在从 cron 作业调用时却不行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4683437/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com