[zeromq-dev] thread safety using inproc sockets for inter-thread communication

Bill Torpey wallstprog at gmail.com
Tue Sep 26 23:22:00 CEST 2017


Hi All:

I don’t see this addressed specifically in the docs, in the GitHub issues, or here, so thought I’d ask.

I bind an inproc sub socket for inter-thread communication, which I include in zmq_poll.  When I want to e.g., subscribe from a different thread I create a pub socket, connect to the first and send it a command message, which then gets executed on the main zmq thread.  So far, so good.

What I’m wondering if it’s OK to immediately disconnect the socket after calling zmq_send, like so:

   void* temp = zmq_socket(impl->mZmqContext, ZMQ_PUB);
   zmq_connect(temp, ZMQ_CONTROL_ENDPOINT);
   zmq_pollitem_t pollitems [] = { { temp, 0, ZMQ_POLLIN, 0 } };
   CALL_ZMQ_FUNC(zmq_poll(pollitems, 1, 1));				// see https://github.com/zeromq/libzmq/issues/2267
   zmq_send(temp, msg, msgSize, 0);
   zmq_disconnect(temp, ZMQ_CONTROL_ENDPOINT);
   zmq_close(temp);

This *seems* to work, but I’m concerned that maybe I’m just getting "lucky”?  It does *not* appear to work with ZMQ_PAIR sockets, for whatever reason, although I’ve seen that approach recommended in a few places. 

Thanks in advance for any assistance!

Regards,

Bill Torpey


More information about the zeromq-dev mailing list