1

我使用 zeromq(最新版本,2012.04.04)、c++、ms vs 2008(x86 发布/调试)、windows 7 x64。我尝试编写简单的客户端-服务器系统。

问题

我的问题是在 Windows 7 上的 recv() 命令中计算机死机,当许多客户端同时连接到服务器时

在 Windows Vista 上,结果就像在 Windows XP 上一样 - 客户端失败:
http://research.makseq.com/testZMQ/2.Vista.png
http://research.makseq.com/testZMQ/1.PNG
在此之后失败的客户端无法连接到服务器,他们写道:
“断言失败:地址已在使用中:...”

这是源代码:

http://research.makseq.com/testZMQ/testZMQ.rar

如何使用:

1)“testZMQ.exe服务器”到服务器启动,

2)按回车并按住“testZMQ.exe”启动多对多客户端。

尝试多次启动服务器:我认为这个错误发生在服务器启动两次或更多次时。

#include "stdafx.h"
#include "../Libraries/zeromq/include/zmq.h"
#include "../Libraries/zeromq/include/zhelpers.hpp"
#include <string>
using namespace std; 

#ifdef WIN32
#pragma comment(lib, "../Libraries/zeromq/libzmq.lib") 
#endif

//-----------------------------------------------------------------------------
int server()
{
    cout << ":: Server ::" << endl;
    zmq::context_t context(1);
    zmq::socket_t server(context, ZMQ_REP);
    server.bind("tcp://*:7774");

    while (1) {

         // receive 
         zmq::message_t messageR;
         cout << "debug point 1" << endl; 
         server.recv(&messageR); // <== dead hanging here
         cout << "debug point 2" << endl; 
         string recieved = string(static_cast<char*>(messageR.data()), messageR.size());

         // send
         string reply = "do something";
         zmq::message_t messageS(reply.size());
         memcpy(messageS.data(), reply.data(), reply.size()); 
         cout << "debug point 3" << endl; 
         server.send(messageS);
         cout << "debug point 4" << endl; 

    }
    return 0;
}

//-----------------------------------------------------------------------------
int client()
{
    cout << ":: Client ::" << endl;
    // connect
    zmq::context_t context(1);
    zmq::socket_t *client = new zmq::socket_t (context, ZMQ_REQ);
    client->connect("tcp://localhost:7774");
    int linger = 0;
    client->setsockopt (ZMQ_LINGER, &linger, sizeof (linger));

    // send
    string reply = "hello";
    zmq::message_t messageS(reply.size());
    memcpy(messageS.data(), reply.data(), reply.size()); 
    client->send(messageS);

    // receive
    zmq::message_t messageR;
    client->recv(&messageR);
    string recieved = string(static_cast<char*>(messageR.data()), messageR.size());

    // close
    client->close();
    delete client;
    zmq_term(&context);

    return 0;
}

int _tmain(int argc, _TCHAR* argv[])
{
    if (argc == 2) server(); 
    else client(); 

    return 0;
}

我做错了什么?

4

2 回答 2

3

recv is a blocking call. Until something connects, it will sit there and wait. It's not a dead hang, it's just waiting for a connection.

于 2012-04-21T21:15:50.937 回答
0

“地址已在使用”错误似乎暗示您对 socket.bind() 的调用发生了多次 - 即您正在运行多个服务器进程。您只能绑定一次到给定接口上的给定端口。

我怀疑这解释了为什么它会导致机器挂起......

于 2013-07-16T12:55:25.163 回答