[CentOS] odd situation slightly off topic (sending file descriptors to another process)

Thu Aug 19 21:51:44 UTC 2010
JohnS <jses27 at gmail.com>

On Thu, 2010-08-19 at 16:22 -0400, Jerry Geis wrote:
> Jerry Geis wrote:
> > I have coded up the standard sendfd() and recvfd() for linux to send 
> > and recv file descriptors.
> > seems to work 
> > (http://book.chinaunix.net/special/ebook/addisonWesley/APUE2/0201433079/ch17lev1sec4.html) 
> >
> > however when I recvfd() my number of open file descriptors bumps by 2 
> > and not 1. (using lsof -p X | wc -l)
> >
> > I am not sure why the count jumps by 2 and not 1. The sendfd() is just 
> > sending a socket descriptor.
> > If I close() the provided descriptor it only closes 1 handle (again 
> > using lsof above).
> >
> > So my recvfd() is giving me 2 but when I close() I only drop 1 and not 
> > 2. Something is not in alignment
> > and just wondering if someone can shed some light on this. Thanks.
> >
> > Jerry
> >
> Here is a diff of the lsof output when a new connection is made and the 
> old connection is closed. The lingering /dev/null is evident. I dont 
> know where that
> is from nor why it does not close upon calling close().
> 
> Jerry
> 
> 13d12
> < kendra  13162 root    4u  IPv4             999539                 TCP 
> devcentos5x64.msgnet.com:6520->am2mm.msgnet.com:52047 (ESTABLISHED)
>  > kendra  13162 root   61u  IPv4             999634                 TCP 
> devcentos5x64.msgnet.com:6520->am2mm.msgnet.com:60390 (ESTABLISHED)
> 73a74
>  > kendra  13162 root   66r   CHR                1,3                1749 
> /dev/null
---
You passing data or what?

You can also do by "lsof -a -p 0000"  "wc" skips things in lsof, you
want every descriptor open
and cat /proc/${PID}/fd/    To make sure.
lsof -i @x.x.x.x for active connections or remaining dead

Passing data to disk fsync() first then close()?

Ahh I read the page you linked and according to it in a client server
like arch the server descriptor will stay open....

"""Closing the descriptor by the sender doesn't really close the file or
device, since the descriptor is still considered open by the receiving
process (even if the receiver hasn't specifically received the
descriptor yet)."""

Kinda what I thought.

ohn