Fix upper limit of superuser_reserved_connections, add limit for wal_senders
authorMagnus Hagander <magnus@hagander.net>
Fri, 10 Aug 2012 12:49:03 +0000 (14:49 +0200)
committerMagnus Hagander <magnus@hagander.net>
Fri, 10 Aug 2012 12:50:45 +0000 (14:50 +0200)
Should be limited to the maximum number of connections excluding
autovacuum workers, not including.

Add similar check for max_wal_senders, which should never be higher than
max_connections.

doc/src/sgml/config.sgml
src/backend/postmaster/postmaster.c

index 43556a1366210357cb5a642d745c32f97e8953c7..e30c5a0cf4e8f1d31c93907bd6894a8b38189005 100644 (file)
@@ -2087,12 +2087,16 @@ SET ENABLE_SEQSCAN TO OFF;
        </indexterm>
        <listitem>
        <para>
-        Specifies the maximum number of concurrent connections from standby
-        servers or streaming base backup clients (i.e., the maximum number of
-        simultaneously running WAL sender
-        processes). The default is zero. This parameter can only be set at
-        server start. <varname>wal_level</> must be set to <literal>archive</>
-        or <literal>hot_standby</> to allow connections from standby servers.
+        Specifies the maximum number of concurrent connections from
+        standby servers or streaming base backup clients (i.e., the
+        maximum number of simultaneously running WAL sender
+        processes). The default is zero, meaning replication is
+        disabled. WAL sender processes count towards the total number
+        of connections, so the parameter cannot be set higher than
+        <xref linkend="guc-max-connections">.  This parameter can only
+        be set at server start. <varname>wal_level</> must be set
+        to <literal>archive</> or <literal>hot_standby</> to allow
+        connections from standby servers.
        </para>
        </listitem>
       </varlistentry>
index bfef707050a82f7842b1e2da550efcfa4882ec82..fee699ea9ef2da504c5ce2b4d9b2284ea37eef06 100644 (file)
@@ -763,11 +763,16 @@ PostmasterMain(int argc, char *argv[])
    /*
     * Check for invalid combinations of GUC settings.
     */
-   if (ReservedBackends >= MaxBackends)
+   if (ReservedBackends >= MaxConnections)
    {
        write_stderr("%s: superuser_reserved_connections must be less than max_connections\n", progname);
        ExitPostmaster(1);
    }
+   if (max_wal_senders >= MaxConnections)
+   {
+       write_stderr("%s: max_wal_senders must be less than max_connections\n", progname);
+       ExitPostmaster(1);
+   }
    if (XLogArchiveMode && wal_level == WAL_LEVEL_MINIMAL)
        ereport(ERROR,
                (errmsg("WAL archival (archive_mode=on) requires wal_level \"archive\" or \"hot_standby\"")));