如何使用php exec shell从crontab获取结果执行Sftp


How can I obtain result execution Sftp with php exec shell from crontab?

当我从终端执行脚本时,它会打印结果sftp
如果php脚本是从cron执行的,那么它不会打印任何内容,$result为空。

Crontab:

23 12 * * *  php script.php >> /tmp/logs.log

脚本:

<?php
$command = 'lftp -u user,Password sftp://domain.com -e "set ftp:passive-mode off; set ftp:auto-passive-mode on; put -O /path/tests toTransfer/file.zip; bye;"';
$result = shell_exec($command);
echo $result;
if ($result) echo "uploaded";
else echo "Not uploaded";
?>

我假设cron在与shell中使用的帐户不同的帐户下运行。

您的脚本可能依赖于您的帐户环境(如具有已知主机密钥的文件)。cron帐户没有,因此lftp失败。

lftp可能在错误输出上打印了一些错误。但您只收集了一个标准输出。

尝试从一个普通的shell脚本开始,并将stdout和stderr重定向到日志文件:

lftp -u user,Password sftp://domain.com 2>&1 > /tmp/log.log

请注意,您正在使用SFTP。因此,设置lftp的FTP特定选项(如ftp:passive-mode)是没有意义的(SFTP中没有被动模式)。