GearmanWorker::setTimeout

(PECL gearman >= 0.6.0)

GearmanWorker::setTimeout Задание тайм-аута ожидания ввода/вывода на сокете

Описание

public GearmanWorker::setTimeout ( int $timeout ) : bool

Устанавливает тайм-аут ожидания активности на сокете.

Список параметров

timeout

Временной интервал в миллисекундах. Отрицательное значение указывает на отсутствие ограничений.

Возвращаемые значения

Всегда возвращает true.

Примеры

Пример #1 Простой обработчик с пятисекундным тайм-аутом

<?php

echo "Запуск\n";

# создаем объект обработчика.
$gmworker= new GearmanWorker();

# добавляем сервер по умолчанию (localhost).
$gmworker->addServer();

# регистрируем функцию "reverse" на сервере
$gmworker->addFunction("reverse""reverse_fn");

# устанавливаем тайм-аут ожидания 5 секунд
$gmworker->setTimeout(5000);

echo 
"Ожидание задания...\n";
while(@
$gmworker->work() || $gmworker->returnCode() == GEARMAN_TIMEOUT)
{
  if (
$gmworker->returnCode() == GEARMAN_TIMEOUT)
  {
    
# Обычно хотелось бы сделать что-то полезное здесь ...
    
echo "Время вышло. Ожидание следующего задания...\n";
    continue;
  }

  if (
$gmworker->returnCode() != GEARMAN_SUCCESS)
  {
    echo 
"Код возврата: " $gmworker->returnCode() . "\n";
    break;
  }
}

echo 
"Готово\n";

function 
reverse_fn($job)
{
  return 
strrev($job->workload());
}

?>

Если запустить этот обработчик и не передавать ему заданий, вывод будет примерно таким:

Запуск
Ожидание задания...
Время вышло. Ожидание следующего задания...
Время вышло. Ожидание следующего задания...
Время вышло. Ожидание следующего задания...

Смотрите также

  • GearmanWorker::timeout() - Получение значения тайм-аута ожидания запросов на сокете