Я начал использовать php-resque (https://github.com/chrisboulton/php-resque) вместе с PHP и MySQL сервером. Я вижу, что «MySQL сервер ушел» ошибки рабочих.
Код очереди на работу:
if ($request->command == 'custom_script') {
//error_log("before queue");
Resque::enqueue($queue, 'AsyncTest', array('text'=>'yolo'));
//error_log("after queue");
}
Класс работы:
class AsyncTest{
public function setUp() {
# Set up something before perform, like establishing a database connection
$mysql = Mysql::getInstance();
EH::setErrorHandler();
}
public function perform()
{
// $mysql = Mysql::getInstance();
// EH::setErrorHandler();
//error_log($this->args['text']);
$haiku_step_query= $mysql->query("SELECT id FROM haiku LIMIT 10 OFFSET 1");
$row = $mysql->fetch_assoc($haiku_step_query);
$haiku_id = $row['id'];
}
public function tearDown() {
# Run after perform, like closing resources
}
}
Я вижу сообщения об ошибке «Сервер MySQL ушел»:
MySQL ERROR №2006 MySQL server has gone away[qs:SELECT id FROM haiku LIMIT 10 OFFSET 1]
(/var/www/html/haiku_server/vendor/chrisboulton/php-resque/resque.php line 77
Resque_Worker->work(5) >> /var/www/html/haiku_server/vendor/chrisboulton/php-resque/lib/Resque/Worker.php line 199
Resque_Worker->perform(Object) >> /var/www/html/haiku_server/vendor/chrisboulton/php-resque/lib/Resque/Worker.php line 237
Resque_Job->perform() >> /var/www/html/haiku_server/vendor/chrisboulton/php-resque/lib/Resque/Job.php line 182
AsyncTest->perform() >> /var/www/html/haiku_server/includes/bgJobs/AsyncThreads.php line 48
Mysql->query("SELECT id FROM haiku LIMIT 10 OFFSET 1") >> /var/www/html/haiku_server/includes/Mysql.class.php line 113 )
Обратите внимание, что этого не происходит, то есть MySQL работает нормально, когда я делаю операцию без php-resque, например:
if ($request->command == 'custom_script') {
$mysql = Mysql::getInstance();
EH::setErrorHandler();
$haiku_step_query= $mysql->query("SELECT id FROM haiku LIMIT 10 OFFSET 1");
$row = $mysql->fetch_assoc($haiku_step_query);
$haiku_id = $row['id'];
}
Посмотрите на эту проблему:
https://github.com/chrisboulton/php-resque/issues/269
Возможная причина в том, что после первого запуска задания ваши объекты останутся загруженными в память, включая ваше соединение MySQL. Решение состоит в том, чтобы повторно подключиться к MySQL в вашем методе execute.
Других решений пока нет …