summaryrefslogtreecommitdiff
path: root/contrib/pgstattuple/sql
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2015-10-13 11:21:33 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2015-10-13 11:21:33 -0400
commit39cd1bdb8655fc897e8cb77613c21acb677709d7 (patch)
tree49df29398dd69a5f954f78b1e6e2d2a85615ab54 /contrib/pgstattuple/sql
parent250108b6f3993e74a83b93c14fc09933799b3e11 (diff)
On Windows, ensure shared memory handle gets closed if not being used.
Postmaster child processes that aren't supposed to be attached to shared memory were not bothering to close the shared memory mapping handle they inherit from the postmaster process. That's mostly harmless, since the handle vanishes anyway when the child process exits -- but the syslogger process, if used, doesn't get killed and restarted during recovery from a backend crash. That meant that Windows doesn't see the shared memory mapping as becoming free, so it doesn't delete it and the postmaster is unable to create a new one, resulting in failure to recover from crashes whenever logging_collector is turned on. Per report from Dmitry Vasilyev. It's a bit astonishing that we'd not figured this out long ago, since it's been broken from the very beginnings of out native Windows support; probably some previously-unexplained trouble reports trace to this. A secondary problem is that on Cygwin (perhaps only in older versions?), exec() may not detach from the shared memory segment after all, in which case these child processes did remain attached to shared memory, posing the risk of an unexpected shared memory clobber if they went off the rails somehow. That may be a long-gone bug, but we can deal with it now if it's still live, by detaching within the infrastructure introduced here to deal with closing the handle. Back-patch to all supported branches. Tom Lane and Amit Kapila
Diffstat (limited to 'contrib/pgstattuple/sql')
0 files changed, 0 insertions, 0 deletions