我一直试图让一个异步服务器与ZeroMQ一起运行C ++(使用cppzmq绑定)。我的文件编译正常,但是我在zmq :: error_t类型的运行时出错:"非套接字"上的套接字操作。
Here's the file that's apparently giving the error.我在asyncsrv example来自" ZeroMQ:指南"之后对此进行了建模,修复了示例中的一些错误(例如尝试std::bind
到因某种原因的矢量)。
如果需要,这是我的class definitions for the related source file。
代码复制:
#include "worker.hpp"
void SkidooshBrokerTask::run() {
frontend.bind("tcp://*:20401");
backend.bind("inproc://backend");
std::vector<SkidooshBrokerWorker *> workers;
std::vector<std::thread *> worker_threads;
for (int i=0; i<kMaxThread; ++i) {
workers.push_back(new SkidooshBrokerWorker(ctx,ZMQ_DEALER));
worker_threads.push_back(new std::thread(std::bind(&SkidooshBrokerWorker::work, workers[workers.size()-1])));
worker_threads[worker_threads.size()-1]->detach();
}
try {
zmq::proxy(&frontend,&backend,nullptr);
} catch (std::exception &e) {
}
for (int i=0;i<kMaxThread; ++i) {
delete workers[i];
delete worker_threads[i];
}
}
void SkidooshBrokerWorker::work() {
wk_sck.connect("inproc://backend");
try {
while (true) {
zmq::message_t identity;
zmq::message_t msg;
zmq::message_t copied_id;
zmq::message_t copied_msg;
std::string rq_str;
wk_sck.recv(&identity);
wk_sck.recv(&msg);
rq_str = std::string(static_cast<char *>(msg.data()),msg.size());
copied_id.copy(&identity);
copied_msg.copy(&msg);
}
} catch (std::exception &e) {}
}
答案 0 :(得分:0)
我知道这是一个迟到的答案。但是当我使用zmq :: poll()时,我遇到了同样的错误。
您可以尝试更改
try
{
zmq::proxy(&frontend,&backend,nullptr);
} catch (std::exception &e) {}
到
try
{
zmq::proxy((void*)(&frontend),(void*)(&backend),nullptr);
} catch (std::exception &e) {}
参考:有关详细信息,请查看this主题。