Re: fcntl(SETLK) [was Re: 2nd update on TOAST] - Mailing list pgsql-hackers

From Mike Mascari
Subject Re: fcntl(SETLK) [was Re: 2nd update on TOAST]
Date
Msg-id 39672498.140BBC13@mascari.com
Whole thread Raw
In response to Re: fcntl(SETLK) [was Re: 2nd update on TOAST]  (Tom Lane <tgl@sss.pgh.pa.us>)
Responses Re: fcntl(SETLK) [was Re: 2nd update on TOAST]  (Alfred Perlstein <bright@wintelcom.net>)
Re: fcntl(SETLK) [was Re: 2nd update on TOAST]  (Bruce Momjian <pgman@candle.pha.pa.us>)
Re: fcntl(SETLK) [was Re: 2nd update on TOAST]  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-hackers
Alfred Perlstein wrote:
> 
> * Jan Wieck <JanWieck@t-online.de> [000708 05:47] wrote:
> > Tom Lane wrote:
> > >
> > > Bruce and I were just talking by phone about this, and we realized that
> > > there is a completely different approach to making that decision: if you
> > > want to know whether there's an old postmaster connected to a socket
> > > file, try to connect to the old postmaster!  In other words, pretend to
> > > be a client and see if your connection attempt is answered.  (You don't
> > > have to try to log in, just see if you get a connection.)  This might
> > > also answer Peter's concern about socket files that belong to
> > > non-Postgres programs, although I doubt that's really a big issue.
> > >
> > > There are some potential pitfalls here, like what if the old postmaster
> > > is there but overloaded?  But on the whole it seems like it might be
> > > a cleaner answer than fooling around with lockfiles, and certainly safer
> > > than relying on fcntl(SETLK) to work on a socket file.  Comments anyone?
> >
> >     Like it.
> 
> my $pgsocket = "/tmp/.s.PGSQL.5432";
> 
> # try to connect to the postmaster
> socket(SOCK, PF_UNIX, SOCK_STREAM, 0)
>         or die "unable to create unix domain socket: $!";
> 
> connect(SOCK, sockaddr_un($pgsocket))
>         and errexit("postmaster is running you must shut it down");
> 
> oh yeah... :)
> 
> -Alfred

I don't get this. Isn't there a race condition here?

Just curious,

Mike Mascari


pgsql-hackers by date:

Previous
From: Alfred Perlstein
Date:
Subject: Re: fcntl(SETLK) [was Re: 2nd update on TOAST]
Next
From: Alfred Perlstein
Date:
Subject: Re: fcntl(SETLK) [was Re: 2nd update on TOAST]