moving Connection/PipeConnection between processes
randall at tnr.cc
Mon Jun 15 07:58:42 CEST 2009
Now that I've done some homework, everything you said is clear.
Mike Kazantsev wrote:
> Pickle has nothing to do with the problem since it lay much deeper: in
> the OS.
> From kernel point of view, every process has it's own "descriptor
> table" and the integer id of the descriptor is all the process gets, so
> when you say "os.pipe()" kernel actually gives you a number which is
> completely meaningless for any other process - it either doesn't exists
> in it's descriptor table or points to something else.
> So, what you actually need is to tell the kernel to duplicate
> underlying object in another process' table (with it's own numbering),
> which is usually done via special flag for sendmsg(2) in C, so you
> should probably look out for py implementation of this call, which I
> haven't stumbled upon, but, admittely, never looked for.
sendmsg is a missing feature of the socket module.
And this implements it:
More information about the Python-list