(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.
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());
}
?>