ZMQSocket::recv

(PECL zmq >= 0.5.0)

ZMQSocket::recvRecibir un mensaje

Descripción

publicZMQSocket::recv(int$mode = 0): string

Recibe un mensaje de un socket. Por defecto, la recepción quedará en espera hasta que haya disponible un mensaje, a menos que se emplee la bandera ZMQ::MODE_DONTWAIT. Se puede emplear la opción de socket ZMQ::SOCKOPT_RCVMORE para recibir mensajes multiparte. Véase ZMQSocket::setSockOpt() para más información.

Parámetros

mode

Proporcionar banderas de modo para recibir mensajes multiparte o hacer que la operación no quede en espera. Véanse las constantes ZMQ::MODE_*.

Valores devueltos

Devuelve el mensaje. Si se emplea ZMQ::MODE_DONTWAIT y la operación debería quedar en espera, se devolverá false.

Errores/Excepciones

Lanza una ZMQSocketException en caso de error.

Ejemplos

Ejemplo #1 Un ejemplo de send/recv

Envío / respuesta sin esperas

<?php


$cola = new ZMQSocket(new ZMQContext(), ZMQ::SOCKET_REQ);
$cola->connect("tcp://127.0.0.1:5555");


$reintentos = 5;
$sending = true;


do {
try {

if ($sending) {
echo
"Enviando el mensaje\n";
$cola->send("Este es un mensaje", ZMQ::MODE_DONTWAIT);
$sending = false;
} else {
echo
"Respuesta obtenida: " . $cola->recv(ZMQ::MODE_DONTWAIT) . "\n";
break;
}
} catch (
ZMQSocketException $e) {

if ($e->getCode() === ZMQ::ERR_EAGAIN) {
echo
" - EAGAIN, reintentando ($reintentos)\n";
} else {
die(
" - Error: " . $e->getMessage());
}
}

usleep(5);
} while (--
$reintentos);
?>

El resultado del ejemplo sería algo similar a:

Enviando el mensaje - Unable to execute operation, retrying (4) Respuesta obtenida: Este es un mensaje
To Top