GearmanWorker::wait

(PECL gearman >= 0.6.0)

GearmanWorker::waitEspera cualquier actividad de uno de los servidores de trabajo

Descripción

public GearmanWorker::wait ( void ) : bool

Provoca que el trabajador espere a cualquier actividad desde uno de los servidores de trabajo Gearman cuando trabaja en modo entrada/salida no bloqueante. En caso de fallo, envía un E_WARNING con el último error Gearman encontrado.

Parámetros

Esta función no tiene parámetros.

Valores devueltos

Devuelve TRUE en caso de éxito o FALSE en caso de error.

Ejemplos

Ejemplo #1 Running worker in non-blocking mode

<?php

echo "Inicializando\n";

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

# Define el trabajador como no bloqueante
$worker->addOptions(GEARMAN_WORKER_NON_BLOCKING); 

# Añade el servidor por defecto (localhost, puerto 4730)
$worker->addServer(); 

# Añade la función reverse
$worker->addFunction('reverse''reverse_fn');

# Intenta obtener un trabajo
while (@$worker->work() ||
       
$worker->returnCode() == GEARMAN_IO_WAIT ||
       
$worker->returnCode() == GEARMAN_NO_JOBS)
{
  if (
$worker->returnCode() == GEARMAN_SUCCESS)
    continue;

  echo 
"Esperando al siguiente trabajo...\n";
  if (!@
$worker->wait()) 
  { 
    if (
$worker->returnCode() == GEARMAN_NO_ACTIVE_FDS
    { 
      
# No estamos conectados a ningún servidor, esperamos antes
      # de reconectar. 
      
sleep(5); 
      continue; 
    } 
    break; 
  } 


echo 
"Error en el trabajador: " $worker->error() . "\n";

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


?>

Ver también