以下为官方给出的 zmq c++多线程 demo ,我的项目也是从这个改版出来的,但是我遇到一个非常严重的问题,当我有多个客户端同时访问的时候就出现了问题。
情况如下:
我们假设 A/B/C 三个客户端,同时发送 a/b/c 给服务器,服务器的工作就是把接收到的字符串完全返回,正常的话,客户端应该接收到的回复也是 a/b/c 。
但是我这里会出现的情况是,收到: a/a/c 或 b/b/c 等
也就是说,会把应该分来应该发送给 a 的,也发送给了 b ,同时 b 的那条就丢失了
这种情况有人遇到过么?
#include <pthread.h>
#include <unistd.h>
#include <cassert>
#include <string>
#include <iostream>
#include <zmq.hpp>
void *worker_routine (void *arg)
{
zmq::context_t *context = (zmq::context_t *) arg;
zmq::socket_t socket (*context, ZMQ_REP);
socket.connect ("inproc://workers");
while (true) {
// Wait for next request from client
zmq::message_t request;
socket.recv (&request);
std::cout << "Received request: [" << (char*) request.data() << "]" << std::endl;
// Do some 'work'
sleep (1);
// Send reply back to client
zmq::message_t reply (6);
memcpy ((void *) reply.data (), "World", 6);
socket.send (reply);
}
return (NULL);
}
int main ()
{
// Prepare our context and sockets
zmq::context_t context (1);
zmq::socket_t clients (context, ZMQ_ROUTER);
clients.bind ("tcp://*:5555");
zmq::socket_t workers (context, ZMQ_DEALER);
workers.bind ("inproc://workers");
// Launch pool of worker threads
for (int thread_nbr = 0; thread_nbr != 5; thread_nbr++) {
pthread_t worker;
pthread_create (&worker, NULL, worker_routine, (void *) &context);
}
// Connect work threads to client threads via a queue
zmq::proxy (clients, workers, NULL);
return 0;
}
1
taozle 2015-11-25 16:57:05 +08:00
如果我没记错的,这种情况应该是要设置`ZMQ_IDENTITY `
|
2
harry890829 OP @taozle 多谢,我查下手册,看看是怎么弄
|
3
harry890829 OP @taozle 查了下手册,顺着 ZMQ_IDENTITY 还看到了 ZMQ_ROUTER_HANDOVER ,是不是我把 ZMQ_ROUTER_HANDOVER 的值设置为 1 之后,就可以了?但是不知道应该修改那个值啊……是修改外部监听的那个 socket 还是 worker 内部的?
|