在生产环境中运行时,Symfony2 Process :: start()失败

时间:2015-03-31 22:07:19

标签: php symfony exec command-line-interface

我正在使用Symfony2 Process组件触发生成相当大的报告的cli脚本。此时我正在使用ajax监视它的进度并在前端显示进度条填充。在app_dev.php中执行以下代码时,它运行完美且没有问题。但是,当我在生产中运行它时,它无法启动Process()。

这是我的代码:

public function generateAction($reportSlug)
    {
        $this->wrangler->addMoodleGlobal('CFG');
        $time = time();

        $commandSlug = "report:{$reportSlug}";
        $console = $this->container->get('kernel')->getRootDir() ."/console";

        $process = new Process("exec php {$console} {$commandSlug} {$time} > /dev/null 2>/dev/null &");

        $process->start();

        return $this->renderJson(json_encode(array(
            'success' => true,
            'message' => "php {$console} {$commandSlug}",
            'time' => $time
        )));
    }

我已经php app/console cache:clear --env="prod"

以及php app/console cache:warmup --env="prod"

bot无济于事。

感谢。

1 个答案:

答案 0 :(得分:1)

当我改变行

时,不确定真正的问题是什么
$process = new Process("exec php {$console} {$commandSlug} {$time} > /dev/null 2>/dev/null &");

使用临时输出文件:

$process = new Process("exec php {$console} {$commandSlug} {$time} > /tmp/output.log 2>/tmp/output.log &");

一切都开始正常运作了。任何人都可以对此有所了解吗?