GearmanWorker::setTimeout

(PECL gearman >= 0.6.0)

GearmanWorker::setTimeoutEstablece un tiempo de espera máximo para actividad de entrada/salida del socket

Descripción

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

Establece el intervalo de tiempo a esperar actividad de entrada/salida del socket. Sets the interval of time to wait for socket I/O activity.

Parámetros

timeout

Un intervalo de tiempo en milisegundos. Un valor negativo indica un tiempo de espera infinito.

Valores devueltos

Retorna siempre TRUE.

Ejemplos

Ejemplo #1 Un trabajador sencillo con un tiempo de espera de 5 segundos

<?php

echo "Empezando\n";

# Crea el objeto trabajador
$gmworker= new GearmanWorker();

# Añade el servidor por defecto (localhost).
$gmworker->addServer();

# Registra la función "reverse" en el servidor.
$gmworker->addFunction("reverse""reverse_fn");

# Establece el tiempo de espera a 5 segundos
$gmworker->setTimeout(5000);

echo 
"Esperando trabajo...\n";
while(@
$gmworker->work() || $gmworker->returnCode() == GEARMAN_TIMEOUT)
{
  if (
$gmworker->returnCode() == GEARMAN_TIMEOUT)
  {
    
# Normalmente se espera hacer algo útil aquí...
    
echo "Timeout. Esperando al siguiente trabajo...\n";
    continue;
  }

  if (
$gmworker->returnCode() != GEARMAN_SUCCESS)
  {
    echo 
"return_code: " $gmworker->returnCode() . "\n";
    break;
  }
}

echo 
"Listo!\n";

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

?>

Ejecutar el trabajador sin enviar trabajos genera una salida que es parecida a:

Empezando
Esperando trabajo...
Timeout. Esperando al siguiente trabajo...
Timeout. Esperando al siguiente trabajo...
Timeout. Esperando al siguiente trabajo...

Ver también