Функция выполнения задания php-resque не выполняется?
Я пытаюсь сделать фоновое задание с php-resque. У меня есть этот код:
\Resque::setBackend('127.0.0.1:6379');
\Resque::enqueue('default', '\BaseModule\Jobs\Mail', array());
и в классе Mail у меня есть это
class Mail
{
public function perform()
{
lakdf;
}
}
Ошибка на "lakdf;" здесь специально.
Когда я включаю монитор на свой redis и пытаюсь выполнить задание, напишите это:
1387283121.312817 [0 127.0.0.1:32827] "set" "resque:worker:michal-pc:9622:default" "{\"queue\":\"default\",\"run_at\":\"Tue Dec 17 12:25:21 UTC 2013\",\"payload\":{\"class\":\"\\\\BaseModule\\\\Jobs\\\\Mail\",\"args\":[[]],\"id\":\"c7c64e218bc951018c2a264eaf5a4b9a\"}}"
1387283121.313312 [0 127.0.0.1:32827] "incrby" "resque:stat:processed" "1"
Итак, из "reque: stat: обработано", я думаю, что моя работа была обработана, но есть ошибка в выполнении функции и ее отсутствие записи каких-либо ошибок, например, функция выполнения никогда не выполняется.
Даже если я сделаю некоторую вставку в базу данных в функции выполнения, он ничего не сделает.
Кто-нибудь знает, где проблема? Почему кажется, что выполнение функции не выполняется?
Ответы
Ответ 1
PHP будет считать, что
lakdf;
является:
$lakdf;
Итак, если вы действительно хотите, чтобы ошибка была выбрана, вы можете заставить ее заменить эту строку следующим образом:
error_log("I am throwing an error from within the Mail::perform function");
Ответ 2
Надеюсь, что это поможет только одной команде:
$command = 'php ' . 'background_process_autoresponder.php';
$a = shell_exec(sprintf('%s > /dev/null 2>&1 &', $command));