Commit 375aa7b3 authored by Tom Lane's avatar Tom Lane

Reduce PG_SYSLOG_LIMIT to 900 bytes.

The previous limit of 1024 was set on the assumption that all modern syslog
implementations have line length limits of 2KB or so.  However, this is
false, as at least Solaris and sysklogd truncate at only 1KB.  900 seems
to leave enough room for the max likely length of the tacked-on prefixes,
so let's go with that.

As with the previous change, it doesn't seem wise to back-patch this into
already-released branches; but it should be OK to sneak it into 9.1.

Noah Misch
parent c4096c76
...@@ -105,11 +105,12 @@ int Log_destination = LOG_DESTINATION_STDERR; ...@@ -105,11 +105,12 @@ int Log_destination = LOG_DESTINATION_STDERR;
/* /*
* Max string length to send to syslog(). Note that this doesn't count the * Max string length to send to syslog(). Note that this doesn't count the
* sequence-number prefix we add, and of course it doesn't count the prefix * sequence-number prefix we add, and of course it doesn't count the prefix
* added by syslog itself. On many implementations it seems that the hard * added by syslog itself. Solaris and sysklogd truncate the final message
* limit is approximately 2K bytes including both those prefixes. * at 1024 bytes, so this value leaves 124 bytes for those prefixes. (Most
* other syslog implementations seem to have limits of 2KB or so.)
*/ */
#ifndef PG_SYSLOG_LIMIT #ifndef PG_SYSLOG_LIMIT
#define PG_SYSLOG_LIMIT 1024 #define PG_SYSLOG_LIMIT 900
#endif #endif
static bool openlog_done = false; static bool openlog_done = false;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment