Crontab不运行php命令

时间:2017-03-15 06:31:16

标签: php linux symfony crontab beanstalkd

我正在使用带有pheanstalk php库的Symfony 3框架。我用Linux Debian Jesse在服务器上运行应用程序。作业创建工作正常,如果从终端运行工作程序,它应该工作。但是当我将命令添加到crontab时,我发现该命令不起作用。没有任何登录/ var / main / user来帮助我进行debuging。我会很高兴得到任何帮助。

这是我的工作人员命令(只有执行功能):

LastEvaluatedKey

这是我的app.queue_manager函数,用于从队列中获取作业并运行命令:

protected function execute(InputInterface $input, OutputInterface $output)
{
    $output->writeln("\n<info>Beanstalk worker service started</info>");
    $tubes = $this->getContainer()->get('app.job_manager.power_plant')->getTubes();
    if ($input->getOption('one-check')) {
        // run once
        foreach ($tubes as $tubeName) {
            if ($tubeName != "default") {
                $this->getContainer()->get('app.queue_manager')->fetchQueue($tubeName);
            }
        }
        $output->writeln("\n<info>Beanstalk worker completed check and stoped</info>");
    } else {
        // run forever
        set_time_limit(0);
        max_execution_time(0);
        while (1) {
            foreach ($tubes as $tubeName) {
                if ($tubeName != "default") {
                    $this->getContainer()->get('app.queue_manager')->fetchQueue($tubeName);
                }
            }
        }
        $output->writeln("\n<info>Beanstalk worker stoped</info>");
    }
}

工作人员运行命令

public function fetchQueue($tubeName)
{
    if ($this->pheanstalk->getConnection()->isServiceListening()) {
        while (true === is_object($job = $this->pheanstalk->watch($tubeName)->ignore('default')->reserve(self::WATCH_TIMEOUT))) {
            $data = json_decode($job->getData(), true);
            $this->worker($data);
            $this->pheanstalk->delete($job);
        }
    }
}

这是我的crontab不起作用:

public function worker($data)
{
    $application = new Application($this->kernel);
    $application->setAutoExit(false);

    $parameters = [];
    $parameters['command'] = $data['command'];
    foreach ($data['meta'] as $key => $param) {
        $parameters[$key] = $param;
    }

    $input = new ArrayInput($parameters);
    $output = new NullOutput();

    return $application->run($input, $output);
}

我创建了另一个正常工作的cron标签。它每15分钟工作一次,不同之处在于没有无限循环(而(1))所以它只通过管子而不是完成。但这不是我想要的。我希望无限循环一直有效,就像我用第一个crontab创建它一样:

@reboot /usr/bin/php /var/www/mose-base/bin/console beanstalk:worker:start

2 个答案:

答案 0 :(得分:0)

如果它在控制台中有效,则它不适用于您的文件用户权限。检查一下。

您可以使用此作业通过电子邮件报告错误

{{1}}

答案 1 :(得分:0)

我使用了rc.local。它解决了这个问题。 Tnx FreudianSlip