【发布时间】:2022-01-23 02:59:26
【问题描述】:
我有一个 PHP 文件,我想将其作为 cron 作业运行。
在服务器上,该文件位于/var/www/html/directory/file.php 并且没有错误,因为它可以通过转到www.exampledomain.com/directory/file.php 在浏览器中运行。
在文件/etc/crontab 我有以下行:
* * * * * root /usr/bin/php /var/www/html/directory/file.php >/dev/null 2>&1
在我的服务器上输入 sudo service cron status 我看到了:
● cron.service - Regular background program processing daemon
Loaded: loaded (/lib/systemd/system/cron.service; enabled; vendor preset: enabled)
Active: active (running) since Thu 2021-07-29 10:23:11 UTC; 4 months 23 days ago
Docs: man:cron(8)
Main PID: 769 (cron)
Tasks: 1 (limit: 1140)
CGroup: /system.slice/cron.service
└─769 /usr/sbin/cron -f
Dec 21 17:46:01 ip-172-31-34-251 CRON[20648]: (ubuntu) CMD (root /usr/bin/php /var/www/html/directory/file.php >/dev/null
Dec 21 17:46:01 ip-172-31-34-251 CRON[20649]: (root) CMD (root /usr/bin/php /var/www/html/directory/file.php >/dev/null 2
Dec 21 17:46:01 ip-172-31-34-251 CRON[20647]: pam_unix(cron:session): session closed for user ubuntu
Dec 21 17:46:01 ip-172-31-34-251 CRON[20646]: pam_unix(cron:session): session closed for user root
Dec 21 17:47:01 ip-172-31-34-251 CRON[20661]: pam_unix(cron:session): session opened for user ubuntu by (uid=0)
Dec 21 17:47:01 ip-172-31-34-251 CRON[20660]: pam_unix(cron:session): session opened for user root by (uid=0)
Dec 21 17:47:01 ip-172-31-34-251 CRON[20662]: (ubuntu) CMD (root /usr/bin/php /var/www/html/directory/file.php >/dev/null
Dec 21 17:47:01 ip-172-31-34-251 CRON[20663]: (root) CMD (root /usr/bin/php /var/www/html/directory/file.php >/dev/null 2
Dec 21 17:47:01 ip-172-31-34-251 CRON[20661]: pam_unix(cron:session): session closed for user ubuntu
Dec 21 17:47:01 ip-172-31-34-251 CRON[20660]: pam_unix(cron:session): session closed for user root
cron 作业应该更新另一个文件,但没有发生。出了什么问题或者我可以做些什么来进一步解决这个问题。以前我会在托管域中使用 cron 作为服务,但最近才开始使用 ubuntu,所以不确定 linux 命令。
【问题讨论】:
-
* * * * *这个表达式的意思是每一分钟。你确定这就是你想要的运行方式吗? -
@nice_dev 我只是将它设置为这种方式进行故障排除,当我真正开始工作时它不会经常运行
-
好的。您可以手动点击
/usr/bin/php /var/www/html/directory/file.php之类的命令行并检查另一个文件是否正在更新?这可能是另一个文件的权限问题。 -
这完全是 PHP 问题吗?还有什么工作吗?确保遵循minimal reproducible example 的精神并删除不相关的部分。此外,您主动抑制了所有输出,因此您不应该对没有得到任何诊断提示感到惊讶。
-
@nice_dev 是的,它可以从命令行正常工作,这是 cron 设置的问题。我在阅读另一篇帖子后添加了
>/dev/null 2>&1,说它正在尝试打印一些东西并通过电子邮件发送给我,但出现错误
标签: php cron ubuntu-18.04