Repair longstanding bug in slru/clog logic: it is possible for two backends
authorTom Lane <[email protected]>
Sat, 21 Jan 2006 04:38:27 +0000 (04:38 +0000)
committerTom Lane <[email protected]>
Sat, 21 Jan 2006 04:38:27 +0000 (04:38 +0000)
commita20dcfe45ddf3cf01263db62f76893c71d6d0381
tree4f80406c3ee2779e4622dac2fab22a23b25a1356
parent4e69e9df3fb058a023d9fc2e2edf68989367540c
Repair longstanding bug in slru/clog logic: it is possible for two backends
to try to create a log segment file concurrently, but the code erroneously
specified O_EXCL to open(), resulting in a needless failure.  Before 7.4,
it was even a PANIC condition :-(.  Correct code is actually simpler than
what we had, because we can just say O_CREAT to start with and not need a
second open() call.  I believe this accounts for several recent reports of
hard-to-reproduce "could not create file ...: File exists" errors in both
pg_clog and pg_subtrans.
src/backend/access/transam/slru.c