我有一个运行以下命令的 cronjob:
* * * * * php/path/to/phpfile.php >>/cronlog.txt
当我在 bash 中运行 php 文件时一切正常,但是当 cronjob 运行它时,一个命令失败:
shell_exec("redis-cli ping");
并返回一个错误 sh: 1: redis-cli: not found
有谁知道为什么使用 PHP shell_exec
的 cron 用户无法使用 redis-cli
命令?
更新
git diff/env_term.txt/env_cron.txt
-SHELL=/bin/bash
-TERM=screen
-SSH_CLIENT=*************
-SSH_TTY=/dev/pts/0
-USER=root
-LS_COLORS=rs=0:di=01;34:ln=01;36:mh=00:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:su=37;41:sg=30;43:ca=30;41:tw=30;42:ow=34;42:st=37;44:ex=01;32:*.
-TERMCAP= { a bunch of giberish }
-PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games
-MAIL=/var/mail/root
-STY=*************
-PWD=*************
-LANG=en_US.UTF-8
-HOME=/root
-SHLVL=2
LANGUAGE=en_US:en
+HOME=/root
LOGNAME=root
-WINDOW=2
-SSH_CONNECTION=*************
-LESSOPEN=| /usr/bin/lesspipe %s
-LESSCLOSE=/usr/bin/lesspipe %s %s
-_=/usr/bin/env
+PATH=/usr/bin:/bin
+LANG=en_US.UTF-8
+SHELL=/bin/sh
+PWD=*************
最佳答案
当调用 cron 时,您是否检查过您的 PATH 变量是否相同。 快速检查是添加一个虚拟 cron 作业以输出传递给 cron 的当前环境变量:
* * * * * env > /tmp/env.out
然后将此输出与从终端运行 env 命令时的输出进行比较
关于php - cron 运行使用 shell_exec 和 redis-cli 的 php 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21956077/