GearmanWorker::wait

(PECL gearman >= 0.6.0)

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

Descripción

public GearmanWorker::wait(): 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

add a note add a note

User Contributed Notes

There are no user contributed notes for this page.
To Top