]> granicus.if.org Git - postgresql/commit
Fix syslogger's rotation disable/re-enable logic.
authorTom Lane <tgl@sss.pgh.pa.us>
Fri, 27 Apr 2012 04:12:42 +0000 (00:12 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Fri, 27 Apr 2012 04:12:42 +0000 (00:12 -0400)
commit537b26695389ae67adc4fbbe04254bc527a11128
treeee0db92368d19b9d249c3cc5982d4bfe0fd0d53e
parent3424bff90f40532527b9cf4f2ad9eaff750682f7
Fix syslogger's rotation disable/re-enable logic.

If it fails to open a new log file, the syslogger assumes there's something
wrong with its parameters (such as log_directory), and stops attempting
automatic time-based or size-based log file rotations.  Sending it SIGHUP
is supposed to start that up again.  However, the original coding for that
was really bogus, involving clobbering a couple of GUC variables and hoping
that SIGHUP processing would restore them.  Get rid of that technique in
favor of maintaining a separate flag showing we've turned rotation off.
Per report from Mark Kirkwood.

Also, the syslogger will automatically attempt to create the log_directory
directory if it doesn't exist, but that was only happening at startup.
For consistency and ease of use, it should do the same whenever the value
of log_directory is changed by SIGHUP.

Back-patch to all supported branches.
src/backend/postmaster/syslogger.c