[zeromq-dev] Issue 85 & 92
Martin Sustrik
sustrik at 250bpm.com
Sat Oct 16 16:42:11 CEST 2010
On 10/16/2010 04:30 PM, Pieter Hintjens wrote:
>> To put it more simply: While your test program is well behaved and doesn't
>> migrate the socket, 0MQ has no way to be sure that. If the client happens to
>> be Erlang VM or somesuch, it can easily migrate the socket to another OS
>> thread without even letting 0MQ know about the fact.
>
> So if you had some API that exotic programs could use to tell
> 0MQ that they wanted to migrate a socket to a new thread, say
> zmq_setsockopt (socket, ZMQ_MIGRATE), this would allow simple programs
> to work simply (and zmq_term to work correctly for them), while asking
> exotic programs to do extra work.
Not even that. The problem is that while you may be notified about the
migration of the socket to the OS thread executing zmq_term, you cannot
directly touch it as you have no guarantee that it won't be migrated to
a different OS thread afterwards.
Anyway, the "exotic programs" means basically any language runtime. I am
not sure that Oracle would modify it's Java VM or that MSFT would tweak
.NET runtime just to work well with 0MQ.
Martin
More information about the zeromq-dev
mailing list