ZMQSocket::__construct
(PECL zmq >= 0.5.0)
ZMQSocket::__construct — Constrói um novo ZMQSocket
Descrição
ZMQContext
$context
,int
$type
,string
$persistent_id
= null
,callable
$on_new_socket
= null
)
Constrói um objeto ZMQSocket. O parâmetro persistent_id
pode ser usado para alocar um socket
persistente. Um socket persistente deve ser alocado a partir de um contexto persistente e permanece conectado ao longo de várias requisições.
O parâmetro persistent_id
pode ser usado para chamar novamente o mesmo socket ao longo de várias requisições. O
parâmetro on_new_socket
é chamado apenas quando uma nova instância de socket for criada.
Parâmetros
context
-
Um objeto ZMQContext.
type
-
O tipo do socket. Consulte as constantes
ZMQ::SOCKET_*
. persistent_id
-
Se o parâmetro
persistent_id
for especificado, o socket será persistente ao longo de várias requisições. Se o parâmetrocontext
não for persistente, o socket volta para o modo não persistente. on_new_socket
-
Uma finção de retorno que é executada quando uma nova instância de socket é criada. Essa função não é invocada se a conexão em uso for persistente e estiver sendo reusada.
Erros/Exceções
Lança um ZMQSocketException em erros.
Exemplos
Example #1 Exemplo de ZMQSocket()
Utilizando um callback para conectar associar um socket
<?php
/*
O socket é persistente e por isso essa função é chamada apanas na
primeira requisição ao script.
*/
function novo_socket_cb(ZMQSocket $socket, $id_persistente = null)
{
if ($id_persistente === 'servidor') {
$socket->bind("tcp://localhost:12122");
} else {
$socket->connect("tcp://localhost:12122");
}
}
/* Aloca um novo contexto */
$contexto = new ZMQContext();
/* Cria um novo socket */
$socket = $context->getSocket(ZMQ::SOCKET_REP, 'servidor', 'novo_socket_cb');
$mensagem = $socket->recv();
echo "Mensagem recebida: {$mensagem}\n";
?>