[zeromq-dev] Thread Safe sockets
Martin Sustrik
sustrik at 250bpm.com
Mon Feb 6 22:13:48 CET 2012
On 06/02/12 22:08, Gary Wright wrote:
>> What makes the problem bad is the fact that there may be arbitrary
>> interval between sending/receiving 1st and 2nd part of the message.
>> During that time the socket has to be locked which in turn means that
>> all other threads accessing it will be blocked for the period (1 hour,
>> for example).
>
>
> You could avoid the indefinitely locking and still have multi-part messages
> by changing the API such that all message parts have to be handed to/from
> the API in one call.
Yes. Standard POSIX gather/scatter arrays.
> At first I thought the multi-part message system would be great for
> streaming chunks of data but each message is buffered within ZMQ
> before being delivered via the API so any sort of streaming
> is going to have to be done via multiple messages anyway. (Someone
> correct me if I'm misunderstanding anything).
Yes. It works that way. That's why I've defined the multi-part messages
earlier on as a simple presentation protocol, a kind of simple XML or JSON.
Martin
More information about the zeromq-dev
mailing list