PHP脚本权限变更会直接导致cron任务失败,因cron用户需对脚本及所有依赖路径(配置、日志、缓存等)具备读写执行权限;必须使用PHP绝对路径、显式设置环境变量与工作目录,并统一属组+setgid解决web与cron用户权限冲突。
修改PHP脚本文件或其所在目录的权限(如用 chmod 或 chown),可能直接导致cron任务失败——不是“可能”,而是只要权限不满足执行用户的需求,就会出错。Linux cron以指定用户身份运行,该用户必须对脚本有读取+执行权限(.php 文件本身需可读;若通过 php /path/to/script.php 方式调用,脚本无需可执行位,但PHP二进制和路径必须可达)。
Permission denied、Command not found、脚本静默退出(无输出且返回码非0)www-data、root 或自定义用户)能否读取脚本?能否访问脚本中涉及的所有文件(配置、日志、缓存目录)?/var/www/myapp/config.php、/tmp/myapp/ 等——cron用户可能没有写入 /tmp 子目录的权限,即使脚本本身可读你在终端里能跑通 php script.php,不代表cron能跑通。cron默认不加载用户shell环境(~/.bashrc、~/.profile),PATH极简(通常是 /usr/bin:/bin),所以直接写 php 很可能找不到命令。
/usr/bin/php 或 /opt/plesk/php/8.1/bin/php(用 which php 查准)__DIR__ 或 dirname(__FILE__) 定位资源,别用相对路径如 ./config.php
sudo -u www-data /usr/bin/php /var/www/myapp/cron.php,比看日志更快定位权限/路径问题很多PHP定时任务会写日志、生成缓存、上传临时文件。如果脚本由web服务器(如nginx + php-fpm)和cron共用,而两者运行用户不同(比如web用 www-data,cron用 root),就极易因目录所有权或umask差异导致后续失败。
failed to open stream: Permission denied —— 因为web用户创建了缓存文件,cron用户没权限覆盖或追加chmod 777,而是统一属组并设置setgid:chgrp www-data /var/www/myapp/runtime + chmod g+rwxs /var/www/myapp/runtime
SHELL=/bin/bash + UMASK=0002,或在脚本开头用 umask(0002)
如果你用的是systemd timer(比如 mytask.timer + mytask.service),权限控制粒度更高:它强制指定 User= 和 Group=,且默认不继承任何环境变量

$HOME 都可能为空。
Environment=PATH=/usr/local/bin:/usr/bin:/bin,否则连 php 都找不到WorkingDirectory= 必须设,否则脚本内 require 'config.php' 会因路径错乱失败journalctl -u mytask.service 查,比 /var/log/syslog 更精准;错误常是 Failed at step USER spawning(用户不存在)或 Permission denied(目标目录不属于该用户)exec()、shell_exec() 调用的外部命令(如 curl、mysqldump)是否也有执行权限,以及这些命令所操作的文件路径是否同样开放给了该用户。