(PECL gearman >= 0.6.0)
GearmanWorker::wait — Espera cualquier actividad de uno de los servidores de trabajo
   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.
  
Esta función no tiene parámetros.
   Devuelve TRUE en caso de éxito o FALSE en caso de error.
  
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());
}
?>