These settings control the behavior of the built-in
streaming replication feature (see
Section 25.2.5).
Some parameters must be set on the master server, while others must be
set on the standby server(s) that will receive replication data.
These parameters can be set on the primary server that is
to send replication data to one or more standby servers.
Note that in addition to these parameters,
wal_level must be set appropriately on the master
server, and you will typically want to enable WAL archiving as
well (see Section 18.5.3).
The values of these parameters on standby servers are irrelevant,
although you may wish to set them there in preparation for the
possibility of a standby becoming the master.
max_wal_senders (integer)
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
max_connections. This parameter can only
be set at server start. wal_level must be set
to archive or hot_standby to allow
connections from standby servers.
wal_sender_delay (integer)
Specifies the delay between activity rounds for WAL sender processes.
In each round the WAL sender sends any WAL accumulated since the last
round to the standby server. It then sleeps for
wal_sender_delay milliseconds, and repeats. The sleep
is interrupted by transaction commit, so the effects of a committed
transaction are sent to standby servers as soon as the commit
happens, regardless of this setting. The default value is one second
(1s).
Note that on many systems, the effective resolution of sleep delays is
10 milliseconds; setting wal_sender_delay to a value that
is not a multiple of 10 might have the same results as setting it to
the next higher multiple of 10. This parameter can only be set in the
postgresql.conf file or on the server command line.
wal_keep_segments (integer)
Specifies the minimum number of past log file segments kept in the
pg_xlog
directory, in case a standby server needs to fetch them for streaming
replication. Each segment is normally 16 megabytes. If a standby
server connected to the primary falls behind by more than
wal_keep_segments segments, the primary might remove
a WAL segment still needed by the standby, in which case the
replication connection will be terminated. (However, the standby
server can recover by fetching the segment from archive, if WAL
archiving is in use.)
This sets only the minimum number of segments retained in
pg_xlog; the system might need to retain more segments
for WAL archival or to recover from a checkpoint. If
wal_keep_segments is zero (the default), the system
doesn't keep any extra segments for standby purposes, so the number
of old WAL segments available to standby servers is a function of
the location of the previous checkpoint and status of WAL
archiving. This parameter has no effect on restartpoints.
This parameter can only be set in the
postgresql.conf file or on the server command line.
vacuum_defer_cleanup_age (integer)
Specifies the number of transactions by which VACUUM and
HOT updates will defer cleanup of dead row versions. The
default is zero transactions, meaning that dead row versions can be
removed as soon as possible, that is, as soon as they are no longer
visible to any open transaction. You may wish to set this to a
non-zero value on a primary server that is supporting hot standby
servers, as described in Section 25.5. This allows
more time for queries on the standby to complete without incurring
conflicts due to early cleanup of rows. However, since the value
is measured in terms of number of write transactions occurring on the
primary server, it is difficult to predict just how much additional
grace time will be made available to standby queries.
This parameter can only be set in the postgresql.conf
file or on the server command line.
You should also consider setting hot_standby_feedback
as an alternative to using this parameter.
replication_timeout (integer)
Terminate replication connections that are inactive longer
than the specified number of milliseconds. This is useful for
the primary server to detect a standby crash or network outage.
A value of zero disables the timeout mechanism. This parameter
can only be set in
the postgresql.conf file or on the server command line.
The default value is 60 seconds.
To prevent connections from being terminated prematurely,
wal_receiver_status_interval
must be enabled on the standby, and its value must be less than the
value of replication_timeout.
synchronous_standby_names (string)
Specifies a comma-separated list of standby names that can support
synchronous replication, as described in
Section 25.2.6.
At any one time there will be at most one active synchronous standby;
transactions waiting for commit will be allowed to proceed after
this standby server confirms receipt of their data.
The synchronous standby will be the first standby named in this list
that is both currently connected and streaming data in real-time
(as shown by a state of streaming in the
pg_stat_replication view).
Other standby servers appearing later in this list represent potential
synchronous standbys.
If the current synchronous standby disconnects for whatever reason,
it will be replaced immediately with the next-highest-priority standby.
Specifying more than one standby name can allow very high availability.
The name of a standby server for this purpose is the
application_name setting of the standby, as set in the
primary_conninfo of the standby's walreceiver. There is
no mechanism to enforce uniqueness. In case of duplicates one of the
matching standbys will be chosen to be the synchronous standby, though
exactly which one is indeterminate.
The special entry * matches any
application_name, including the default application name
of walreceiver.
If no synchronous standby names are specified here, then synchronous
replication is not enabled and transaction commits will not wait for
replication. This is the default configuration. Even when
synchronous replication is enabled, individual transactions can be
configured not to wait for replication by setting the
synchronous_commit parameter to
local or off.
This parameter can only be set in the postgresql.conf
file or on the server command line.
These settings control the behavior of a standby server that is
to receive replication data. Their values on the master server
are irrelevant.
hot_standby (boolean)
Specifies whether or not you can connect and run queries during
recovery, as described in Section 25.5.
The default value is off.
This parameter can only be set at server start. It only has effect
during archive recovery or in standby mode.
max_standby_archive_delay (integer)
When Hot Standby is active, this parameter determines how long the
standby server should wait before canceling standby queries that
conflict with about-to-be-applied WAL entries, as described in
Section 25.5.2.
max_standby_archive_delay applies when WAL data is
being read from WAL archive (and is therefore not current).
The default is 30 seconds. Units are milliseconds if not specified.
A value of -1 allows the standby to wait forever for conflicting
queries to complete.
This parameter can only be set in the postgresql.conf
file or on the server command line.
Note that max_standby_archive_delay is not the same as the
maximum length of time a query can run before cancellation; rather it
is the maximum total time allowed to apply any one WAL segment's data.
Thus, if one query has resulted in significant delay earlier in the
WAL segment, subsequent conflicting queries will have much less grace
time.
max_standby_streaming_delay (integer)
When Hot Standby is active, this parameter determines how long the
standby server should wait before canceling standby queries that
conflict with about-to-be-applied WAL entries, as described in
Section 25.5.2.
max_standby_streaming_delay applies when WAL data is
being received via streaming replication.
The default is 30 seconds. Units are milliseconds if not specified.
A value of -1 allows the standby to wait forever for conflicting
queries to complete.
This parameter can only be set in the postgresql.conf
file or on the server command line.
Note that max_standby_streaming_delay is not the same as
the maximum length of time a query can run before cancellation; rather
it is the maximum total time allowed to apply WAL data once it has
been received from the primary server. Thus, if one query has
resulted in significant delay, subsequent conflicting queries will
have much less grace time until the standby server has caught up
again.
wal_receiver_status_interval (integer)
Specifies the minimum frequency for the WAL receiver
process on the standby to send information about replication progress
to the primary, where it can be seen using the
pg_stat_replication view. The standby will report
the last transaction log position it has written, the last position it
has flushed to disk, and the last position it has applied.
This parameter's
value is the maximum interval, in seconds, between reports. Updates are
sent each time the write or flush positions change, or at least as
often as specified by this parameter. Thus, the apply position may
lag slightly behind the true position. Setting this parameter to zero
disables status updates completely. This parameter can only be set in
the postgresql.conf file or on the server command line.
The default value is 10 seconds.
When replication_timeout is enabled on the primary,
wal_receiver_status_interval must be enabled, and its value
must be less than the value of replication_timeout.
hot_standby_feedback (boolean)
Specifies whether or not a hot standby will send feedback to the primary
about queries currently executing on the standby. This parameter can
be used to eliminate query cancels caused by cleanup records, but
can cause database bloat on the primary for some workloads.
Feedback messages will not be sent more frequently than once per
wal_receiver_status_interval. The default value is
off. This parameter can only be set in the
postgresql.conf file or on the server command line.