(PECL zmq >= 0.5.0)
ZMQSocket::__construct — Constrói um novo ZMQSocket
$context,$type,$persistent_id = null,$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.
  
contextUm 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âmetro context não for persistente, o socket volta para o modo não persistente.
      
on_new_socketUma 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.
Lança um ZMQSocketException em erros.
Exemplo #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";
?>