Commit c1a7f64b authored by Peter Eisentraut's avatar Peter Eisentraut

Replace "transaction log" with "write-ahead log"

This makes documentation and error messages match the renaming of "xlog"
to "wal" in APIs and file naming.
parent 56b6ef89
...@@ -1424,7 +1424,7 @@ restore_command = 'cp /mnt/server/archivedir/%f %p' ...@@ -1424,7 +1424,7 @@ restore_command = 'cp /mnt/server/archivedir/%f %p'
As with base backups, the easiest way to produce a standalone As with base backups, the easiest way to produce a standalone
hot backup is to use the <xref linkend="app-pgbasebackup"> hot backup is to use the <xref linkend="app-pgbasebackup">
tool. If you include the <literal>-X</> parameter when calling tool. If you include the <literal>-X</> parameter when calling
it, all the transaction log required to use the backup will be it, all the write-ahead log required to use the backup will be
included in the backup automatically, and no special action is included in the backup automatically, and no special action is
required to restore the backup. required to restore the backup.
</para> </para>
......
...@@ -3312,7 +3312,7 @@ ANY <replaceable class="parameter">num_sync</replaceable> ( <replaceable class=" ...@@ -3312,7 +3312,7 @@ ANY <replaceable class="parameter">num_sync</replaceable> ( <replaceable class="
to the primary or upstream standby, where it can be seen using the to the primary or upstream standby, where it can be seen using the
<link linkend="monitoring-stats-views-table"> <link linkend="monitoring-stats-views-table">
<literal>pg_stat_replication</></link> view. The standby will report <literal>pg_stat_replication</></link> view. The standby will report
the last transaction log position it has written, the last position it the last write-ahead log position it has written, the last position it
has flushed to disk, and the last position it has applied. has flushed to disk, and the last position it has applied.
This parameter's This parameter's
value is the maximum interval, in seconds, between reports. Updates are value is the maximum interval, in seconds, between reports. Updates are
......
This diff is collapsed.
...@@ -138,7 +138,7 @@ protocol to make nodes agree on a serializable transactional order. ...@@ -138,7 +138,7 @@ protocol to make nodes agree on a serializable transactional order.
</varlistentry> </varlistentry>
<varlistentry> <varlistentry>
<term>Transaction Log Shipping</term> <term>Write-Ahead Log Shipping</term>
<listitem> <listitem>
<para> <para>
...@@ -289,7 +289,7 @@ protocol to make nodes agree on a serializable transactional order. ...@@ -289,7 +289,7 @@ protocol to make nodes agree on a serializable transactional order.
<entry>Feature</entry> <entry>Feature</entry>
<entry>Shared Disk Failover</entry> <entry>Shared Disk Failover</entry>
<entry>File System Replication</entry> <entry>File System Replication</entry>
<entry>Transaction Log Shipping</entry> <entry>Write-Ahead Log Shipping</entry>
<entry>Trigger-Based Master-Standby Replication</entry> <entry>Trigger-Based Master-Standby Replication</entry>
<entry>Statement-Based Replication Middleware</entry> <entry>Statement-Based Replication Middleware</entry>
<entry>Asynchronous Multimaster Replication</entry> <entry>Asynchronous Multimaster Replication</entry>
...@@ -1036,7 +1036,7 @@ primary_slot_name = 'node_a_slot' ...@@ -1036,7 +1036,7 @@ primary_slot_name = 'node_a_slot'
<para> <para>
When requesting synchronous replication, each commit of a When requesting synchronous replication, each commit of a
write transaction will wait until confirmation is write transaction will wait until confirmation is
received that the commit has been written to the transaction log on disk received that the commit has been written to the write-ahead log on disk
of both the primary and standby server. The only possibility that data of both the primary and standby server. The only possibility that data
can be lost is if both the primary and the standby suffer crashes at the can be lost is if both the primary and the standby suffer crashes at the
same time. This can provide a much higher level of durability, though only same time. This can provide a much higher level of durability, though only
......
...@@ -1032,7 +1032,7 @@ postgres 27093 0.0 0.0 30096 2752 ? Ss 11:34 0:00 postgres: ser ...@@ -1032,7 +1032,7 @@ postgres 27093 0.0 0.0 30096 2752 ? Ss 11:34 0:00 postgres: ser
</row> </row>
<row> <row>
<entry><literal>CLogTruncationLock</></entry> <entry><literal>CLogTruncationLock</></entry>
<entry>Waiting to truncate the transaction log or waiting for transaction log truncation to finish.</entry> <entry>Waiting to truncate the write-ahead log or waiting for write-ahead log truncation to finish.</entry>
</row> </row>
<row> <row>
<entry><literal>clog</></entry> <entry><literal>clog</></entry>
...@@ -1701,24 +1701,24 @@ SELECT pid, wait_event_type, wait_event FROM pg_stat_activity WHERE wait_event i ...@@ -1701,24 +1701,24 @@ SELECT pid, wait_event_type, wait_event FROM pg_stat_activity WHERE wait_event i
<row> <row>
<entry><structfield>sent_lsn</></entry> <entry><structfield>sent_lsn</></entry>
<entry><type>pg_lsn</></entry> <entry><type>pg_lsn</></entry>
<entry>Last transaction log location sent on this connection</entry> <entry>Last write-ahead log location sent on this connection</entry>
</row> </row>
<row> <row>
<entry><structfield>write_lsn</></entry> <entry><structfield>write_lsn</></entry>
<entry><type>pg_lsn</></entry> <entry><type>pg_lsn</></entry>
<entry>Last transaction log location written to disk by this standby <entry>Last write-ahead log location written to disk by this standby
server</entry> server</entry>
</row> </row>
<row> <row>
<entry><structfield>flush_lsn</></entry> <entry><structfield>flush_lsn</></entry>
<entry><type>pg_lsn</></entry> <entry><type>pg_lsn</></entry>
<entry>Last transaction log location flushed to disk by this standby <entry>Last write-ahead log location flushed to disk by this standby
server</entry> server</entry>
</row> </row>
<row> <row>
<entry><structfield>replay_lsn</></entry> <entry><structfield>replay_lsn</></entry>
<entry><type>pg_lsn</></entry> <entry><type>pg_lsn</></entry>
<entry>Last transaction log location replayed into the database on this <entry>Last write-ahead log location replayed into the database on this
standby server</entry> standby server</entry>
</row> </row>
<row> <row>
...@@ -1865,7 +1865,7 @@ SELECT pid, wait_event_type, wait_event FROM pg_stat_activity WHERE wait_event i ...@@ -1865,7 +1865,7 @@ SELECT pid, wait_event_type, wait_event FROM pg_stat_activity WHERE wait_event i
<row> <row>
<entry><structfield>receive_start_lsn</></entry> <entry><structfield>receive_start_lsn</></entry>
<entry><type>pg_lsn</></entry> <entry><type>pg_lsn</></entry>
<entry>First transaction log position used when WAL receiver is <entry>First write-ahead log position used when WAL receiver is
started</entry> started</entry>
</row> </row>
<row> <row>
...@@ -1876,14 +1876,14 @@ SELECT pid, wait_event_type, wait_event FROM pg_stat_activity WHERE wait_event i ...@@ -1876,14 +1876,14 @@ SELECT pid, wait_event_type, wait_event FROM pg_stat_activity WHERE wait_event i
<row> <row>
<entry><structfield>received_lsn</></entry> <entry><structfield>received_lsn</></entry>
<entry><type>pg_lsn</></entry> <entry><type>pg_lsn</></entry>
<entry>Last transaction log position already received and flushed to <entry>Last write-ahead log position already received and flushed to
disk, the initial value of this field being the first log position used disk, the initial value of this field being the first log position used
when WAL receiver is started</entry> when WAL receiver is started</entry>
</row> </row>
<row> <row>
<entry><structfield>received_tli</></entry> <entry><structfield>received_tli</></entry>
<entry><type>integer</></entry> <entry><type>integer</></entry>
<entry>Timeline number of last transaction log position received and <entry>Timeline number of last write-ahead log position received and
flushed to disk, the initial value of this field being the timeline flushed to disk, the initial value of this field being the timeline
number of the first log position used when WAL receiver is started number of the first log position used when WAL receiver is started
</entry> </entry>
...@@ -1901,12 +1901,12 @@ SELECT pid, wait_event_type, wait_event FROM pg_stat_activity WHERE wait_event i ...@@ -1901,12 +1901,12 @@ SELECT pid, wait_event_type, wait_event FROM pg_stat_activity WHERE wait_event i
<row> <row>
<entry><structfield>latest_end_lsn</></entry> <entry><structfield>latest_end_lsn</></entry>
<entry><type>pg_lsn</></entry> <entry><type>pg_lsn</></entry>
<entry>Last transaction log position reported to origin WAL sender</entry> <entry>Last write-ahead log position reported to origin WAL sender</entry>
</row> </row>
<row> <row>
<entry><structfield>latest_end_time</></entry> <entry><structfield>latest_end_time</></entry>
<entry><type>timestamp with time zone</></entry> <entry><type>timestamp with time zone</></entry>
<entry>Time of last transaction log position reported to origin WAL sender</entry> <entry>Time of last write-ahead log position reported to origin WAL sender</entry>
</row> </row>
<row> <row>
<entry><structfield>slot_name</></entry> <entry><structfield>slot_name</></entry>
...@@ -1967,7 +1967,7 @@ SELECT pid, wait_event_type, wait_event FROM pg_stat_activity WHERE wait_event i ...@@ -1967,7 +1967,7 @@ SELECT pid, wait_event_type, wait_event FROM pg_stat_activity WHERE wait_event i
<row> <row>
<entry><structfield>received_lsn</></entry> <entry><structfield>received_lsn</></entry>
<entry><type>pg_lsn</></entry> <entry><type>pg_lsn</></entry>
<entry>Last transaction log position received, the initial value of <entry>Last write-ahead log position received, the initial value of
this field being 0</entry> this field being 0</entry>
</row> </row>
<row> <row>
...@@ -1984,13 +1984,13 @@ SELECT pid, wait_event_type, wait_event FROM pg_stat_activity WHERE wait_event i ...@@ -1984,13 +1984,13 @@ SELECT pid, wait_event_type, wait_event FROM pg_stat_activity WHERE wait_event i
<row> <row>
<entry><structfield>latest_end_lsn</></entry> <entry><structfield>latest_end_lsn</></entry>
<entry><type>pg_lsn</></entry> <entry><type>pg_lsn</></entry>
<entry>Last transaction log position reported to origin WAL sender <entry>Last write-ahead log position reported to origin WAL sender
</entry> </entry>
</row> </row>
<row> <row>
<entry><structfield>latest_end_time</></entry> <entry><structfield>latest_end_time</></entry>
<entry><type>timestamp with time zone</></entry> <entry><type>timestamp with time zone</></entry>
<entry>Time of last transaction log position reported to origin WAL <entry>Time of last write-ahead log position reported to origin WAL
sender</entry> sender</entry>
</row> </row>
</tbody> </tbody>
......
...@@ -1547,7 +1547,7 @@ The commands accepted in walsender mode are: ...@@ -1547,7 +1547,7 @@ The commands accepted in walsender mode are:
<listitem> <listitem>
<para> <para>
Current WAL flush location. Useful to get a known location in the Current WAL flush location. Useful to get a known location in the
transaction log where streaming can start. write-ahead log where streaming can start.
</para> </para>
</listitem> </listitem>
</varlistentry> </varlistentry>
......
...@@ -242,7 +242,7 @@ restore_command = 'copy "C:\\server\\archivedir\\%f" "%p"' # Windows ...@@ -242,7 +242,7 @@ restore_command = 'copy "C:\\server\\archivedir\\%f" "%p"' # Windows
</term> </term>
<listitem> <listitem>
<para> <para>
This parameter specifies the LSN of the transaction log location up This parameter specifies the LSN of the write-ahead log location up
to which recovery will proceed. The precise stopping point is also to which recovery will proceed. The precise stopping point is also
influenced by <xref linkend="recovery-target-inclusive">. This influenced by <xref linkend="recovery-target-inclusive">. This
parameter is parsed using the system data type parameter is parsed using the system data type
......
...@@ -13,7 +13,7 @@ ...@@ -13,7 +13,7 @@
<refnamediv> <refnamediv>
<refname>CHECKPOINT</refname> <refname>CHECKPOINT</refname>
<refpurpose>force a transaction log checkpoint</refpurpose> <refpurpose>force a write-ahead log checkpoint</refpurpose>
</refnamediv> </refnamediv>
<refsynopsisdiv> <refsynopsisdiv>
...@@ -26,7 +26,7 @@ CHECKPOINT ...@@ -26,7 +26,7 @@ CHECKPOINT
<title>Description</title> <title>Description</title>
<para> <para>
A checkpoint is a point in the transaction log sequence at which A checkpoint is a point in the write-ahead log sequence at which
all data files have been updated to reflect the information in the all data files have been updated to reflect the information in the
log. All data files will be flushed to disk. Refer to log. All data files will be flushed to disk. Refer to
<xref linkend="wal-configuration"> for more details about what happens <xref linkend="wal-configuration"> for more details about what happens
......
...@@ -320,7 +320,7 @@ PostgreSQL documentation ...@@ -320,7 +320,7 @@ PostgreSQL documentation
<term><option>--waldir=<replaceable class="parameter">directory</replaceable></option></term> <term><option>--waldir=<replaceable class="parameter">directory</replaceable></option></term>
<listitem> <listitem>
<para> <para>
This option specifies the directory where the transaction log This option specifies the directory where the write-ahead log
should be stored. should be stored.
</para> </para>
</listitem> </listitem>
......
...@@ -178,8 +178,8 @@ PostgreSQL documentation ...@@ -178,8 +178,8 @@ PostgreSQL documentation
target directory, the tar contents will be written to target directory, the tar contents will be written to
standard output, suitable for piping to for example standard output, suitable for piping to for example
<productname>gzip</productname>. This is only possible if <productname>gzip</productname>. This is only possible if
the cluster has no additional tablespaces and transaction the cluster has no additional tablespaces and WAL
log streaming is not used. streaming is not used.
</para> </para>
</listitem> </listitem>
</varlistentry> </varlistentry>
...@@ -299,9 +299,9 @@ PostgreSQL documentation ...@@ -299,9 +299,9 @@ PostgreSQL documentation
<term><option>--waldir=<replaceable class="parameter">waldir</replaceable></option></term> <term><option>--waldir=<replaceable class="parameter">waldir</replaceable></option></term>
<listitem> <listitem>
<para> <para>
Specifies the location for the transaction log directory. Specifies the location for the write-ahead log directory.
<replaceable>waldir</replaceable> must be an absolute path. <replaceable>waldir</replaceable> must be an absolute path.
The transaction log directory can only be specified when The write-ahead log directory can only be specified when
the backup is in plain mode. the backup is in plain mode.
</para> </para>
</listitem> </listitem>
...@@ -312,15 +312,15 @@ PostgreSQL documentation ...@@ -312,15 +312,15 @@ PostgreSQL documentation
<term><option>--wal-method=<replaceable class="parameter">method</replaceable></option></term> <term><option>--wal-method=<replaceable class="parameter">method</replaceable></option></term>
<listitem> <listitem>
<para> <para>
Includes the required transaction log files (WAL files) in the Includes the required write-ahead log files (WAL files) in the
backup. This will include all transaction logs generated during backup. This will include all write-ahead logs generated during
the backup. Unless the method <literal>none</literal> is specified, the backup. Unless the method <literal>none</literal> is specified,
it is possible to start a postmaster directly in the extracted it is possible to start a postmaster directly in the extracted
directory without the need to consult the log archive, thus directory without the need to consult the log archive, thus
making this a completely standalone backup. making this a completely standalone backup.
</para> </para>
<para> <para>
The following methods for collecting the transaction logs are The following methods for collecting the write-ahead logs are
supported: supported:
<variablelist> <variablelist>
...@@ -329,7 +329,7 @@ PostgreSQL documentation ...@@ -329,7 +329,7 @@ PostgreSQL documentation
<term><literal>none</literal></term> <term><literal>none</literal></term>
<listitem> <listitem>
<para> <para>
Don't include transaction log in the backup. Don't include write-ahead log in the backup.
</para> </para>
</listitem> </listitem>
</varlistentry> </varlistentry>
...@@ -339,7 +339,7 @@ PostgreSQL documentation ...@@ -339,7 +339,7 @@ PostgreSQL documentation
<term><literal>fetch</literal></term> <term><literal>fetch</literal></term>
<listitem> <listitem>
<para> <para>
The transaction log files are collected at the end of the backup. The write-ahead log files are collected at the end of the backup.
Therefore, it is necessary for the Therefore, it is necessary for the
<xref linkend="guc-wal-keep-segments"> parameter to be set high <xref linkend="guc-wal-keep-segments"> parameter to be set high
enough that the log is not removed before the end of the backup. enough that the log is not removed before the end of the backup.
...@@ -347,7 +347,7 @@ PostgreSQL documentation ...@@ -347,7 +347,7 @@ PostgreSQL documentation
backup will fail and be unusable. backup will fail and be unusable.
</para> </para>
<para> <para>
The transaction log files will be written to The write-ahead log files will be written to
the <filename>base.tar</filename> file. the <filename>base.tar</filename> file.
</para> </para>
</listitem> </listitem>
...@@ -358,16 +358,16 @@ PostgreSQL documentation ...@@ -358,16 +358,16 @@ PostgreSQL documentation
<term><literal>stream</literal></term> <term><literal>stream</literal></term>
<listitem> <listitem>
<para> <para>
Stream the transaction log while the backup is created. This will Stream the write-ahead log while the backup is created. This will
open a second connection to the server and start streaming the open a second connection to the server and start streaming the
transaction log in parallel while running the backup. Therefore, write-ahead log in parallel while running the backup. Therefore,
it will use up two connections configured by the it will use up two connections configured by the
<xref linkend="guc-max-wal-senders"> parameter. As long as the <xref linkend="guc-max-wal-senders"> parameter. As long as the
client can keep up with transaction log received, using this mode client can keep up with write-ahead log received, using this mode
requires no extra transaction logs to be saved on the master. requires no extra write-ahead logs to be saved on the master.
</para> </para>
<para> <para>
The transaction log files are written to a separate file The write-ahead log files are written to a separate file
named <filename>pg_wal.tar</filename> (if the server is a version named <filename>pg_wal.tar</filename> (if the server is a version
earlier than 10, the file will be named <filename>pg_xlog.tar</filename>). earlier than 10, the file will be named <filename>pg_xlog.tar</filename>).
</para> </para>
...@@ -443,7 +443,7 @@ PostgreSQL documentation ...@@ -443,7 +443,7 @@ PostgreSQL documentation
By default, when <command>pg_basebackup</command> aborts with an By default, when <command>pg_basebackup</command> aborts with an
error, it removes any directories it might have created before error, it removes any directories it might have created before
discovering that it cannot finish the job (for example, data directory discovering that it cannot finish the job (for example, data directory
and transaction log directory). This option inhibits tidying-up and is and write-ahead log directory). This option inhibits tidying-up and is
thus useful for debugging. thus useful for debugging.
</para> </para>
......
...@@ -16,7 +16,7 @@ PostgreSQL documentation ...@@ -16,7 +16,7 @@ PostgreSQL documentation
<refnamediv> <refnamediv>
<refname>pg_receivewal</refname> <refname>pg_receivewal</refname>
<refpurpose>stream transaction logs from a <productname>PostgreSQL</productname> server</refpurpose> <refpurpose>stream write-ahead logs from a <productname>PostgreSQL</productname> server</refpurpose>
</refnamediv> </refnamediv>
<refsynopsisdiv> <refsynopsisdiv>
...@@ -31,8 +31,8 @@ PostgreSQL documentation ...@@ -31,8 +31,8 @@ PostgreSQL documentation
Description Description
</title> </title>
<para> <para>
<application>pg_receivewal</application> is used to stream the transaction log <application>pg_receivewal</application> is used to stream the write-ahead log
from a running <productname>PostgreSQL</productname> cluster. The transaction from a running <productname>PostgreSQL</productname> cluster. The write-ahead
log is streamed using the streaming replication protocol, and is written log is streamed using the streaming replication protocol, and is written
to a local directory of files. This directory can be used as the archive to a local directory of files. This directory can be used as the archive
location for doing a restore using point-in-time recovery (see location for doing a restore using point-in-time recovery (see
...@@ -40,7 +40,7 @@ PostgreSQL documentation ...@@ -40,7 +40,7 @@ PostgreSQL documentation
</para> </para>
<para> <para>
<application>pg_receivewal</application> streams the transaction <application>pg_receivewal</application> streams the write-ahead
log in real time as it's being generated on the server, and does not wait log in real time as it's being generated on the server, and does not wait
for segments to complete like <xref linkend="guc-archive-command"> does. for segments to complete like <xref linkend="guc-archive-command"> does.
For this reason, it is not necessary to set For this reason, it is not necessary to set
...@@ -56,7 +56,7 @@ PostgreSQL documentation ...@@ -56,7 +56,7 @@ PostgreSQL documentation
</para> </para>
<para> <para>
The transaction log is streamed over a regular The write-ahead log is streamed over a regular
<productname>PostgreSQL</productname> connection and uses the replication <productname>PostgreSQL</productname> connection and uses the replication
protocol. The connection must be made with a superuser or a user protocol. The connection must be made with a superuser or a user
having <literal>REPLICATION</literal> permissions (see having <literal>REPLICATION</literal> permissions (see
...@@ -186,7 +186,7 @@ PostgreSQL documentation ...@@ -186,7 +186,7 @@ PostgreSQL documentation
<term><option>--compress=<replaceable class="parameter">level</replaceable></option></term> <term><option>--compress=<replaceable class="parameter">level</replaceable></option></term>
<listitem> <listitem>
<para> <para>
Enables gzip compression of transaction logs, and specifies the Enables gzip compression of write-ahead logs, and specifies the
compression level (0 through 9, 0 being no compression and 9 being best compression level (0 through 9, 0 being no compression and 9 being best
compression). The suffix <filename>.gz</filename> will compression). The suffix <filename>.gz</filename> will
automatically be added to all filenames. automatically be added to all filenames.
...@@ -366,7 +366,7 @@ PostgreSQL documentation ...@@ -366,7 +366,7 @@ PostgreSQL documentation
When using <application>pg_receivewal</application> instead of When using <application>pg_receivewal</application> instead of
<xref linkend="guc-archive-command"> as the main WAL backup method, it is <xref linkend="guc-archive-command"> as the main WAL backup method, it is
strongly recommended to use replication slots. Otherwise, the server is strongly recommended to use replication slots. Otherwise, the server is
free to recycle or remove transaction log files before they are backed up, free to recycle or remove write-ahead log files before they are backed up,
because it does not have any information, either because it does not have any information, either
from <xref linkend="guc-archive-command"> or the replication slots, about from <xref linkend="guc-archive-command"> or the replication slots, about
how far the WAL stream has been archived. Note, however, that a how far the WAL stream has been archived. Note, however, that a
...@@ -380,7 +380,7 @@ PostgreSQL documentation ...@@ -380,7 +380,7 @@ PostgreSQL documentation
<title>Examples</title> <title>Examples</title>
<para> <para>
To stream the transaction log from the server at To stream the write-ahead log from the server at
<literal>mydbserver</literal> and store it in the local directory <literal>mydbserver</literal> and store it in the local directory
<filename>/usr/local/pgsql/archive</filename>: <filename>/usr/local/pgsql/archive</filename>:
<screen> <screen>
......
...@@ -614,7 +614,7 @@ pgbench <optional> <replaceable>options</> </optional> <replaceable>dbname</> ...@@ -614,7 +614,7 @@ pgbench <optional> <replaceable>options</> </optional> <replaceable>dbname</>
<term><option>--log-prefix=<replaceable>prefix</></option></term> <term><option>--log-prefix=<replaceable>prefix</></option></term>
<listitem> <listitem>
<para> <para>
Set the filename prefix for the transaction log files created by Set the filename prefix for the log files created by
<option>--log</>. The default is <literal>pgbench_log</>. <option>--log</>. The default is <literal>pgbench_log</>.
</para> </para>
</listitem> </listitem>
......
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
problem. However, differences shown by problem. However, differences shown by
<application>pg_test_fsync</application> might not make any significant <application>pg_test_fsync</application> might not make any significant
difference in real database throughput, especially since many database servers difference in real database throughput, especially since many database servers
are not speed-limited by their transaction logs. are not speed-limited by their write-ahead logs.
<application>pg_test_fsync</application> reports average file sync operation <application>pg_test_fsync</application> reports average file sync operation
time in microseconds for each <literal>wal_sync_method</literal>, which can also be used to time in microseconds for each <literal>wal_sync_method</literal>, which can also be used to
inform efforts to optimize the value of <xref linkend="guc-commit-delay">. inform efforts to optimize the value of <xref linkend="guc-commit-delay">.
......
...@@ -2517,7 +2517,7 @@ ...@@ -2517,7 +2517,7 @@
2016-12-21 [ecbdc4c55] Forbid invalid combination of options in pg_basebackup. 2016-12-21 [ecbdc4c55] Forbid invalid combination of options in pg_basebackup.
--> -->
<para> <para>
Allow <application>pg_basebackup</> to stream transaction log in Allow <application>pg_basebackup</> to stream write-ahead log in
tar mode (Magnus Hagander) tar mode (Magnus Hagander)
</para> </para>
......
...@@ -151,7 +151,7 @@ readTimeLineHistory(TimeLineID targetTLI) ...@@ -151,7 +151,7 @@ readTimeLineHistory(TimeLineID targetTLI)
if (nfields != 3) if (nfields != 3)
ereport(FATAL, ereport(FATAL,
(errmsg("syntax error in history file: %s", fline), (errmsg("syntax error in history file: %s", fline),
errhint("Expected a transaction log switchpoint location."))); errhint("Expected a write-ahead log switchpoint location.")));
if (result && tli <= lasttli) if (result && tli <= lasttli)
ereport(FATAL, ereport(FATAL,
......
/*------------------------------------------------------------------------- /*-------------------------------------------------------------------------
* *
* transam.c * transam.c
* postgres transaction log interface routines * postgres transaction (commit) log interface routines
* *
* Portions Copyright (c) 1996-2017, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2017, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
......
/*------------------------------------------------------------------------- /*-------------------------------------------------------------------------
* *
* xlog.c * xlog.c
* PostgreSQL transaction log manager * PostgreSQL write-ahead log manager
* *
* *
* Portions Copyright (c) 1996-2017, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2017, PostgreSQL Global Development Group
...@@ -3532,7 +3532,7 @@ XLogFileOpen(XLogSegNo segno) ...@@ -3532,7 +3532,7 @@ XLogFileOpen(XLogSegNo segno)
if (fd < 0) if (fd < 0)
ereport(PANIC, ereport(PANIC,
(errcode_for_file_access(), (errcode_for_file_access(),
errmsg("could not open transaction log file \"%s\": %m", path))); errmsg("could not open write-ahead log file \"%s\": %m", path)));
return fd; return fd;
} }
...@@ -3838,7 +3838,7 @@ RemoveOldXlogFiles(XLogSegNo segno, XLogRecPtr PriorRedoPtr, XLogRecPtr endptr) ...@@ -3838,7 +3838,7 @@ RemoveOldXlogFiles(XLogSegNo segno, XLogRecPtr PriorRedoPtr, XLogRecPtr endptr)
if (xldir == NULL) if (xldir == NULL)
ereport(ERROR, ereport(ERROR,
(errcode_for_file_access(), (errcode_for_file_access(),
errmsg("could not open transaction log directory \"%s\": %m", errmsg("could not open write-ahead log directory \"%s\": %m",
XLOGDIR))); XLOGDIR)));
/* /*
...@@ -3913,7 +3913,7 @@ RemoveNonParentXlogFiles(XLogRecPtr switchpoint, TimeLineID newTLI) ...@@ -3913,7 +3913,7 @@ RemoveNonParentXlogFiles(XLogRecPtr switchpoint, TimeLineID newTLI)
if (xldir == NULL) if (xldir == NULL)
ereport(ERROR, ereport(ERROR,
(errcode_for_file_access(), (errcode_for_file_access(),
errmsg("could not open transaction log directory \"%s\": %m", errmsg("could not open write-ahead log directory \"%s\": %m",
XLOGDIR))); XLOGDIR)));
/* /*
...@@ -3994,7 +3994,7 @@ RemoveXlogFile(const char *segname, XLogRecPtr PriorRedoPtr, XLogRecPtr endptr) ...@@ -3994,7 +3994,7 @@ RemoveXlogFile(const char *segname, XLogRecPtr PriorRedoPtr, XLogRecPtr endptr)
true, recycleSegNo, true)) true, recycleSegNo, true))
{ {
ereport(DEBUG2, ereport(DEBUG2,
(errmsg("recycled transaction log file \"%s\"", (errmsg("recycled write-ahead log file \"%s\"",
segname))); segname)));
CheckpointStats.ckpt_segs_recycled++; CheckpointStats.ckpt_segs_recycled++;
/* Needn't recheck that slot on future iterations */ /* Needn't recheck that slot on future iterations */
...@@ -4006,7 +4006,7 @@ RemoveXlogFile(const char *segname, XLogRecPtr PriorRedoPtr, XLogRecPtr endptr) ...@@ -4006,7 +4006,7 @@ RemoveXlogFile(const char *segname, XLogRecPtr PriorRedoPtr, XLogRecPtr endptr)
int rc; int rc;
ereport(DEBUG2, ereport(DEBUG2,
(errmsg("removing transaction log file \"%s\"", (errmsg("removing write-ahead log file \"%s\"",
segname))); segname)));
#ifdef WIN32 #ifdef WIN32
...@@ -4026,7 +4026,7 @@ RemoveXlogFile(const char *segname, XLogRecPtr PriorRedoPtr, XLogRecPtr endptr) ...@@ -4026,7 +4026,7 @@ RemoveXlogFile(const char *segname, XLogRecPtr PriorRedoPtr, XLogRecPtr endptr)
{ {
ereport(LOG, ereport(LOG,
(errcode_for_file_access(), (errcode_for_file_access(),
errmsg("could not rename old transaction log file \"%s\": %m", errmsg("could not rename old write-ahead log file \"%s\": %m",
path))); path)));
return; return;
} }
...@@ -4108,7 +4108,7 @@ CleanupBackupHistory(void) ...@@ -4108,7 +4108,7 @@ CleanupBackupHistory(void)
if (xldir == NULL) if (xldir == NULL)
ereport(ERROR, ereport(ERROR,
(errcode_for_file_access(), (errcode_for_file_access(),
errmsg("could not open transaction log directory \"%s\": %m", errmsg("could not open write-ahead log directory \"%s\": %m",
XLOGDIR))); XLOGDIR)));
while ((xlde = ReadDir(xldir, XLOGDIR)) != NULL) while ((xlde = ReadDir(xldir, XLOGDIR)) != NULL)
...@@ -4117,9 +4117,8 @@ CleanupBackupHistory(void) ...@@ -4117,9 +4117,8 @@ CleanupBackupHistory(void)
{ {
if (XLogArchiveCheckDone(xlde->d_name)) if (XLogArchiveCheckDone(xlde->d_name))
{ {
ereport(DEBUG2, elog(DEBUG2, "removing WAL backup history file \"%s\"",
(errmsg("removing transaction log backup history file \"%s\"", xlde->d_name);
xlde->d_name)));
snprintf(path, sizeof(path), XLOGDIR "/%s", xlde->d_name); snprintf(path, sizeof(path), XLOGDIR "/%s", xlde->d_name);
unlink(path); unlink(path);
XLogArchiveCleanup(xlde->d_name); XLogArchiveCleanup(xlde->d_name);
...@@ -5074,7 +5073,7 @@ BootStrapXLOG(void) ...@@ -5074,7 +5073,7 @@ BootStrapXLOG(void)
errno = ENOSPC; errno = ENOSPC;
ereport(PANIC, ereport(PANIC,
(errcode_for_file_access(), (errcode_for_file_access(),
errmsg("could not write bootstrap transaction log file: %m"))); errmsg("could not write bootstrap write-ahead log file: %m")));
} }
pgstat_report_wait_end(); pgstat_report_wait_end();
...@@ -5082,13 +5081,13 @@ BootStrapXLOG(void) ...@@ -5082,13 +5081,13 @@ BootStrapXLOG(void)
if (pg_fsync(openLogFile) != 0) if (pg_fsync(openLogFile) != 0)
ereport(PANIC, ereport(PANIC,
(errcode_for_file_access(), (errcode_for_file_access(),
errmsg("could not fsync bootstrap transaction log file: %m"))); errmsg("could not fsync bootstrap write-ahead log file: %m")));
pgstat_report_wait_end(); pgstat_report_wait_end();
if (close(openLogFile)) if (close(openLogFile))
ereport(PANIC, ereport(PANIC,
(errcode_for_file_access(), (errcode_for_file_access(),
errmsg("could not close bootstrap transaction log file: %m"))); errmsg("could not close bootstrap write-ahead log file: %m")));
openLogFile = -1; openLogFile = -1;
...@@ -8432,7 +8431,7 @@ LogCheckpointEnd(bool restartpoint) ...@@ -8432,7 +8431,7 @@ LogCheckpointEnd(bool restartpoint)
average_usecs = average_sync_time - (uint64) average_secs *1000000; average_usecs = average_sync_time - (uint64) average_secs *1000000;
elog(LOG, "%s complete: wrote %d buffers (%.1f%%); " elog(LOG, "%s complete: wrote %d buffers (%.1f%%); "
"%d transaction log file(s) added, %d removed, %d recycled; " "%d WAL file(s) added, %d removed, %d recycled; "
"write=%ld.%03d s, sync=%ld.%03d s, total=%ld.%03d s; " "write=%ld.%03d s, sync=%ld.%03d s, total=%ld.%03d s; "
"sync files=%d, longest=%ld.%03d s, average=%ld.%03d s; " "sync files=%d, longest=%ld.%03d s, average=%ld.%03d s; "
"distance=%d kB, estimate=%d kB", "distance=%d kB, estimate=%d kB",
...@@ -8842,7 +8841,7 @@ CreateCheckPoint(int flags) ...@@ -8842,7 +8841,7 @@ CreateCheckPoint(int flags)
*/ */
if (shutdown && checkPoint.redo != ProcLastRecPtr) if (shutdown && checkPoint.redo != ProcLastRecPtr)
ereport(PANIC, ereport(PANIC,
(errmsg("concurrent transaction log activity while database system is shutting down"))); (errmsg("concurrent write-ahead log activity while database system is shutting down")));
/* /*
* Remember the prior checkpoint's redo pointer, used later to determine * Remember the prior checkpoint's redo pointer, used later to determine
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* *
* xlogfuncs.c * xlogfuncs.c
* *
* PostgreSQL transaction log manager user interface functions * PostgreSQL write-ahead log manager user interface functions
* *
* This file contains WAL control and information functions. * This file contains WAL control and information functions.
* *
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* *
* xlogutils.c * xlogutils.c
* *
* PostgreSQL transaction log manager utility routines * PostgreSQL write-ahead log manager utility routines
* *
* This file contains support routines that are used by XLOG replay functions. * This file contains support routines that are used by XLOG replay functions.
* None of this code is used during normal system operation. * None of this code is used during normal system operation.
......
...@@ -626,9 +626,8 @@ CheckArchiveTimeout(void) ...@@ -626,9 +626,8 @@ CheckArchiveTimeout(void)
* assume nothing happened. * assume nothing happened.
*/ */
if ((switchpoint % XLogSegSize) != 0) if ((switchpoint % XLogSegSize) != 0)
ereport(DEBUG1, elog(DEBUG1, "write-ahead log switch forced (archive_timeout=%d)",
(errmsg("transaction log switch forced (archive_timeout=%d)", XLogArchiveTimeout);
XLogArchiveTimeout)));
} }
/* /*
......
...@@ -482,7 +482,7 @@ pgarch_ArchiverCopyLoop(void) ...@@ -482,7 +482,7 @@ pgarch_ArchiverCopyLoop(void)
if (++failures >= NUM_ARCHIVE_RETRIES) if (++failures >= NUM_ARCHIVE_RETRIES)
{ {
ereport(WARNING, ereport(WARNING,
(errmsg("archiving transaction log file \"%s\" failed too many times, will try again later", (errmsg("archiving write-ahead log file \"%s\" failed too many times, will try again later",
xlog))); xlog)));
return; /* give up archiving for now */ return; /* give up archiving for now */
} }
...@@ -628,8 +628,7 @@ pgarch_archiveXlog(char *xlog) ...@@ -628,8 +628,7 @@ pgarch_archiveXlog(char *xlog)
return false; return false;
} }
ereport(DEBUG1, elog(DEBUG1, "archived write-ahead log file \"%s\"", xlog);
(errmsg("archived transaction log file \"%s\"", xlog)));
snprintf(activitymsg, sizeof(activitymsg), "last was %s", xlog); snprintf(activitymsg, sizeof(activitymsg), "last was %s", xlog);
set_ps_display(activitymsg, false); set_ps_display(activitymsg, false);
......
...@@ -5036,7 +5036,7 @@ sigusr1_handler(SIGNAL_ARGS) ...@@ -5036,7 +5036,7 @@ sigusr1_handler(SIGNAL_ARGS)
{ {
/* /*
* Send SIGUSR1 to archiver process, to wake it up and begin archiving * Send SIGUSR1 to archiver process, to wake it up and begin archiving
* next transaction log file. * next WAL file.
*/ */
signal_child(PgArchPID, SIGUSR1); signal_child(PgArchPID, SIGUSR1);
} }
......
...@@ -563,19 +563,19 @@ exit_nicely(void) ...@@ -563,19 +563,19 @@ exit_nicely(void)
if (made_new_xlogdir) if (made_new_xlogdir)
{ {
fprintf(stderr, _("%s: removing transaction log directory \"%s\"\n"), fprintf(stderr, _("%s: removing WAL directory \"%s\"\n"),
progname, xlog_dir); progname, xlog_dir);
if (!rmtree(xlog_dir, true)) if (!rmtree(xlog_dir, true))
fprintf(stderr, _("%s: failed to remove transaction log directory\n"), fprintf(stderr, _("%s: failed to remove WAL directory\n"),
progname); progname);
} }
else if (found_existing_xlogdir) else if (found_existing_xlogdir)
{ {
fprintf(stderr, fprintf(stderr,
_("%s: removing contents of transaction log directory \"%s\"\n"), _("%s: removing contents of WAL directory \"%s\"\n"),
progname, xlog_dir); progname, xlog_dir);
if (!rmtree(xlog_dir, false)) if (!rmtree(xlog_dir, false))
fprintf(stderr, _("%s: failed to remove contents of transaction log directory\n"), fprintf(stderr, _("%s: failed to remove contents of WAL directory\n"),
progname); progname);
} }
/* otherwise died during startup, do nothing! */ /* otherwise died during startup, do nothing! */
...@@ -589,7 +589,7 @@ exit_nicely(void) ...@@ -589,7 +589,7 @@ exit_nicely(void)
if (made_new_xlogdir || found_existing_xlogdir) if (made_new_xlogdir || found_existing_xlogdir)
fprintf(stderr, fprintf(stderr,
_("%s: transaction log directory \"%s\" not removed at user's request\n"), _("%s: WAL directory \"%s\" not removed at user's request\n"),
progname, xlog_dir); progname, xlog_dir);
} }
...@@ -2704,7 +2704,7 @@ create_data_directory(void) ...@@ -2704,7 +2704,7 @@ create_data_directory(void)
} }
/* Create transaction log directory, and symlink if required */ /* Create WAL directory, and symlink if required */
void void
create_xlog_or_symlink(void) create_xlog_or_symlink(void)
{ {
...@@ -2721,7 +2721,7 @@ create_xlog_or_symlink(void) ...@@ -2721,7 +2721,7 @@ create_xlog_or_symlink(void)
canonicalize_path(xlog_dir); canonicalize_path(xlog_dir);
if (!is_absolute_path(xlog_dir)) if (!is_absolute_path(xlog_dir))
{ {
fprintf(stderr, _("%s: transaction log directory location must be an absolute path\n"), progname); fprintf(stderr, _("%s: WAL directory location must be an absolute path\n"), progname);
exit_nicely(); exit_nicely();
} }
...@@ -2775,8 +2775,8 @@ create_xlog_or_symlink(void) ...@@ -2775,8 +2775,8 @@ create_xlog_or_symlink(void)
warn_on_mount_point(ret); warn_on_mount_point(ret);
else else
fprintf(stderr, fprintf(stderr,
_("If you want to store the transaction log there, either\n" _("If you want to store the WAL there, either remove or empty the directory\n"
"remove or empty the directory \"%s\".\n"), "\"%s\".\n"),
xlog_dir); xlog_dir);
exit_nicely(); exit_nicely();
......
...@@ -174,19 +174,19 @@ cleanup_directories_atexit(void) ...@@ -174,19 +174,19 @@ cleanup_directories_atexit(void)
if (made_new_xlogdir) if (made_new_xlogdir)
{ {
fprintf(stderr, _("%s: removing transaction log directory \"%s\"\n"), fprintf(stderr, _("%s: removing WAL directory \"%s\"\n"),
progname, xlog_dir); progname, xlog_dir);
if (!rmtree(xlog_dir, true)) if (!rmtree(xlog_dir, true))
fprintf(stderr, _("%s: failed to remove transaction log directory\n"), fprintf(stderr, _("%s: failed to remove WAL directory\n"),
progname); progname);
} }
else if (found_existing_xlogdir) else if (found_existing_xlogdir)
{ {
fprintf(stderr, fprintf(stderr,
_("%s: removing contents of transaction log directory \"%s\"\n"), _("%s: removing contents of WAL directory \"%s\"\n"),
progname, xlog_dir); progname, xlog_dir);
if (!rmtree(xlog_dir, false)) if (!rmtree(xlog_dir, false))
fprintf(stderr, _("%s: failed to remove contents of transaction log directory\n"), fprintf(stderr, _("%s: failed to remove contents of WAL directory\n"),
progname); progname);
} }
} }
...@@ -199,7 +199,7 @@ cleanup_directories_atexit(void) ...@@ -199,7 +199,7 @@ cleanup_directories_atexit(void)
if (made_new_xlogdir || found_existing_xlogdir) if (made_new_xlogdir || found_existing_xlogdir)
fprintf(stderr, fprintf(stderr,
_("%s: transaction log directory \"%s\" not removed at user's request\n"), _("%s: WAL directory \"%s\" not removed at user's request\n"),
progname, xlog_dir); progname, xlog_dir);
} }
...@@ -341,7 +341,7 @@ usage(void) ...@@ -341,7 +341,7 @@ usage(void)
" relocate tablespace in OLDDIR to NEWDIR\n")); " relocate tablespace in OLDDIR to NEWDIR\n"));
printf(_(" -X, --wal-method=none|fetch|stream\n" printf(_(" -X, --wal-method=none|fetch|stream\n"
" include required WAL files with specified method\n")); " include required WAL files with specified method\n"));
printf(_(" --waldir=WALDIR location for the transaction log directory\n")); printf(_(" --waldir=WALDIR location for the write-ahead log directory\n"));
printf(_(" -z, --gzip compress tar output\n")); printf(_(" -z, --gzip compress tar output\n"));
printf(_(" -Z, --compress=0-9 compress tar output with given compression level\n")); printf(_(" -Z, --compress=0-9 compress tar output with given compression level\n"));
printf(_("\nGeneral options:\n")); printf(_("\nGeneral options:\n"));
...@@ -414,7 +414,7 @@ reached_end_position(XLogRecPtr segendpos, uint32 timeline, ...@@ -414,7 +414,7 @@ reached_end_position(XLogRecPtr segendpos, uint32 timeline,
if (sscanf(xlogend, "%X/%X", &hi, &lo) != 2) if (sscanf(xlogend, "%X/%X", &hi, &lo) != 2)
{ {
fprintf(stderr, fprintf(stderr,
_("%s: could not parse transaction log location \"%s\"\n"), _("%s: could not parse write-ahead log location \"%s\"\n"),
progname, xlogend); progname, xlogend);
exit(1); exit(1);
} }
...@@ -549,7 +549,7 @@ StartLogStreamer(char *startpos, uint32 timeline, char *sysidentifier) ...@@ -549,7 +549,7 @@ StartLogStreamer(char *startpos, uint32 timeline, char *sysidentifier)
if (sscanf(startpos, "%X/%X", &hi, &lo) != 2) if (sscanf(startpos, "%X/%X", &hi, &lo) != 2)
{ {
fprintf(stderr, fprintf(stderr,
_("%s: could not parse transaction log location \"%s\"\n"), _("%s: could not parse write-ahead log location \"%s\"\n"),
progname, startpos); progname, startpos);
disconnect_and_exit(1); disconnect_and_exit(1);
} }
...@@ -1404,7 +1404,7 @@ ReceiveAndUnpackTarFile(PGconn *conn, PGresult *res, int rownum) ...@@ -1404,7 +1404,7 @@ ReceiveAndUnpackTarFile(PGconn *conn, PGresult *res, int rownum)
/* /*
* When streaming WAL, pg_wal (or pg_xlog for pre-9.6 * When streaming WAL, pg_wal (or pg_xlog for pre-9.6
* clusters) will have been created by the wal receiver * clusters) will have been created by the wal receiver
* process. Also, when transaction log directory location * process. Also, when the WAL directory location
* was specified, pg_wal (or pg_xlog) has already been * was specified, pg_wal (or pg_xlog) has already been
* created as a symbolic link before starting the actual * created as a symbolic link before starting the actual
* backup. So just ignore creation failures on related * backup. So just ignore creation failures on related
...@@ -1817,7 +1817,7 @@ BaseBackup(void) ...@@ -1817,7 +1817,7 @@ BaseBackup(void)
MemSet(xlogend, 0, sizeof(xlogend)); MemSet(xlogend, 0, sizeof(xlogend));
if (verbose && includewal != NO_WAL) if (verbose && includewal != NO_WAL)
fprintf(stderr, _("%s: transaction log start point: %s on timeline %u\n"), fprintf(stderr, _("%s: write-ahead log start point: %s on timeline %u\n"),
progname, xlogstart, starttli); progname, xlogstart, starttli);
/* /*
...@@ -1907,20 +1907,20 @@ BaseBackup(void) ...@@ -1907,20 +1907,20 @@ BaseBackup(void)
if (PQresultStatus(res) != PGRES_TUPLES_OK) if (PQresultStatus(res) != PGRES_TUPLES_OK)
{ {
fprintf(stderr, fprintf(stderr,
_("%s: could not get transaction log end position from server: %s"), _("%s: could not get write-ahead log end position from server: %s"),
progname, PQerrorMessage(conn)); progname, PQerrorMessage(conn));
disconnect_and_exit(1); disconnect_and_exit(1);
} }
if (PQntuples(res) != 1) if (PQntuples(res) != 1)
{ {
fprintf(stderr, fprintf(stderr,
_("%s: no transaction log end position returned from server\n"), _("%s: no write-ahead log end position returned from server\n"),
progname); progname);
disconnect_and_exit(1); disconnect_and_exit(1);
} }
strlcpy(xlogend, PQgetvalue(res, 0, 0), sizeof(xlogend)); strlcpy(xlogend, PQgetvalue(res, 0, 0), sizeof(xlogend));
if (verbose && includewal != NO_WAL) if (verbose && includewal != NO_WAL)
fprintf(stderr, _("%s: transaction log end point: %s\n"), progname, xlogend); fprintf(stderr, _("%s: write-ahead log end point: %s\n"), progname, xlogend);
PQclear(res); PQclear(res);
res = PQgetResult(conn); res = PQgetResult(conn);
...@@ -1998,7 +1998,7 @@ BaseBackup(void) ...@@ -1998,7 +1998,7 @@ BaseBackup(void)
if (sscanf(xlogend, "%X/%X", &hi, &lo) != 2) if (sscanf(xlogend, "%X/%X", &hi, &lo) != 2)
{ {
fprintf(stderr, fprintf(stderr,
_("%s: could not parse transaction log location \"%s\"\n"), _("%s: could not parse write-ahead log location \"%s\"\n"),
progname, xlogend); progname, xlogend);
disconnect_and_exit(1); disconnect_and_exit(1);
} }
...@@ -2312,7 +2312,7 @@ main(int argc, char **argv) ...@@ -2312,7 +2312,7 @@ main(int argc, char **argv)
if (format == 't' && includewal == STREAM_WAL && strcmp(basedir, "-") == 0) if (format == 't' && includewal == STREAM_WAL && strcmp(basedir, "-") == 0)
{ {
fprintf(stderr, fprintf(stderr,
_("%s: cannot stream transaction logs in tar mode to stdout\n"), _("%s: cannot stream write-ahead logs in tar mode to stdout\n"),
progname); progname);
fprintf(stderr, _("Try \"%s --help\" for more information.\n"), fprintf(stderr, _("Try \"%s --help\" for more information.\n"),
progname); progname);
...@@ -2348,7 +2348,7 @@ main(int argc, char **argv) ...@@ -2348,7 +2348,7 @@ main(int argc, char **argv)
if (format != 'p') if (format != 'p')
{ {
fprintf(stderr, fprintf(stderr,
_("%s: transaction log directory location can only be specified in plain mode\n"), _("%s: WAL directory location can only be specified in plain mode\n"),
progname); progname);
fprintf(stderr, _("Try \"%s --help\" for more information.\n"), fprintf(stderr, _("Try \"%s --help\" for more information.\n"),
progname); progname);
...@@ -2359,7 +2359,7 @@ main(int argc, char **argv) ...@@ -2359,7 +2359,7 @@ main(int argc, char **argv)
canonicalize_path(xlog_dir); canonicalize_path(xlog_dir);
if (!is_absolute_path(xlog_dir)) if (!is_absolute_path(xlog_dir))
{ {
fprintf(stderr, _("%s: transaction log directory location must be " fprintf(stderr, _("%s: WAL directory location must be "
"an absolute path\n"), progname); "an absolute path\n"), progname);
fprintf(stderr, _("Try \"%s --help\" for more information.\n"), fprintf(stderr, _("Try \"%s --help\" for more information.\n"),
progname); progname);
...@@ -2393,7 +2393,7 @@ main(int argc, char **argv) ...@@ -2393,7 +2393,7 @@ main(int argc, char **argv)
exit(1); exit(1);
} }
/* Create transaction log symlink, if required */ /* Create pg_wal symlink, if required */
if (strcmp(xlog_dir, "") != 0) if (strcmp(xlog_dir, "") != 0)
{ {
char *linkloc; char *linkloc;
......
/*------------------------------------------------------------------------- /*-------------------------------------------------------------------------
* *
* pg_receivewal.c - receive streaming transaction log data and write it * pg_receivewal.c - receive streaming WAL data and write it
* to a local file. * to a local file.
* *
* Author: Magnus Hagander <magnus@hagander.net> * Author: Magnus Hagander <magnus@hagander.net>
...@@ -71,18 +71,18 @@ static bool stop_streaming(XLogRecPtr segendpos, uint32 timeline, ...@@ -71,18 +71,18 @@ static bool stop_streaming(XLogRecPtr segendpos, uint32 timeline,
static void static void
usage(void) usage(void)
{ {
printf(_("%s receives PostgreSQL streaming transaction logs.\n\n"), printf(_("%s receives PostgreSQL streaming write-ahead logs.\n\n"),
progname); progname);
printf(_("Usage:\n")); printf(_("Usage:\n"));
printf(_(" %s [OPTION]...\n"), progname); printf(_(" %s [OPTION]...\n"), progname);
printf(_("\nOptions:\n")); printf(_("\nOptions:\n"));
printf(_(" -D, --directory=DIR receive transaction log files into this directory\n")); printf(_(" -D, --directory=DIR receive write-ahead log files into this directory\n"));
printf(_(" --if-not-exists do not error if slot already exists when creating a slot\n")); printf(_(" --if-not-exists do not error if slot already exists when creating a slot\n"));
printf(_(" -n, --no-loop do not loop on connection lost\n")); printf(_(" -n, --no-loop do not loop on connection lost\n"));
printf(_(" -s, --status-interval=SECS\n" printf(_(" -s, --status-interval=SECS\n"
" time between status packets sent to server (default: %d)\n"), (standby_message_timeout / 1000)); " time between status packets sent to server (default: %d)\n"), (standby_message_timeout / 1000));
printf(_(" -S, --slot=SLOTNAME replication slot to use\n")); printf(_(" -S, --slot=SLOTNAME replication slot to use\n"));
printf(_(" --synchronous flush transaction log immediately after writing\n")); printf(_(" --synchronous flush write-ahead log immediately after writing\n"));
printf(_(" -v, --verbose output verbose messages\n")); printf(_(" -v, --verbose output verbose messages\n"));
printf(_(" -V, --version output version information, then exit\n")); printf(_(" -V, --version output version information, then exit\n"));
printf(_(" -Z, --compress=0-9 compress logs with given compression level\n")); printf(_(" -Z, --compress=0-9 compress logs with given compression level\n"));
......
/*------------------------------------------------------------------------- /*-------------------------------------------------------------------------
* *
* receivelog.c - receive transaction log files using the streaming * receivelog.c - receive WAL files using the streaming
* replication protocol. * replication protocol.
* *
* Author: Magnus Hagander <magnus@hagander.net> * Author: Magnus Hagander <magnus@hagander.net>
...@@ -116,7 +116,7 @@ open_walfile(StreamCtl *stream, XLogRecPtr startpoint) ...@@ -116,7 +116,7 @@ open_walfile(StreamCtl *stream, XLogRecPtr startpoint)
if (size < 0) if (size < 0)
{ {
fprintf(stderr, fprintf(stderr,
_("%s: could not get size of transaction log file \"%s\": %s\n"), _("%s: could not get size of write-ahead log file \"%s\": %s\n"),
progname, fn, stream->walmethod->getlasterror()); progname, fn, stream->walmethod->getlasterror());
return false; return false;
} }
...@@ -127,7 +127,7 @@ open_walfile(StreamCtl *stream, XLogRecPtr startpoint) ...@@ -127,7 +127,7 @@ open_walfile(StreamCtl *stream, XLogRecPtr startpoint)
if (f == NULL) if (f == NULL)
{ {
fprintf(stderr, fprintf(stderr,
_("%s: could not open existing transaction log file \"%s\": %s\n"), _("%s: could not open existing write-ahead log file \"%s\": %s\n"),
progname, fn, stream->walmethod->getlasterror()); progname, fn, stream->walmethod->getlasterror());
return false; return false;
} }
...@@ -136,7 +136,7 @@ open_walfile(StreamCtl *stream, XLogRecPtr startpoint) ...@@ -136,7 +136,7 @@ open_walfile(StreamCtl *stream, XLogRecPtr startpoint)
if (stream->walmethod->sync(f) != 0) if (stream->walmethod->sync(f) != 0)
{ {
fprintf(stderr, fprintf(stderr,
_("%s: could not sync existing transaction log file \"%s\": %s\n"), _("%s: could not sync existing write-ahead log file \"%s\": %s\n"),
progname, fn, stream->walmethod->getlasterror()); progname, fn, stream->walmethod->getlasterror());
stream->walmethod->close(f, CLOSE_UNLINK); stream->walmethod->close(f, CLOSE_UNLINK);
return false; return false;
...@@ -151,7 +151,7 @@ open_walfile(StreamCtl *stream, XLogRecPtr startpoint) ...@@ -151,7 +151,7 @@ open_walfile(StreamCtl *stream, XLogRecPtr startpoint)
if (errno == 0) if (errno == 0)
errno = ENOSPC; errno = ENOSPC;
fprintf(stderr, fprintf(stderr,
_("%s: transaction log file \"%s\" has %d bytes, should be 0 or %d\n"), _("%s: write-ahead log file \"%s\" has %d bytes, should be 0 or %d\n"),
progname, fn, (int) size, XLogSegSize); progname, fn, (int) size, XLogSegSize);
return false; return false;
} }
...@@ -164,7 +164,7 @@ open_walfile(StreamCtl *stream, XLogRecPtr startpoint) ...@@ -164,7 +164,7 @@ open_walfile(StreamCtl *stream, XLogRecPtr startpoint)
if (f == NULL) if (f == NULL)
{ {
fprintf(stderr, fprintf(stderr,
_("%s: could not open transaction log file \"%s\": %s\n"), _("%s: could not open write-ahead log file \"%s\": %s\n"),
progname, fn, stream->walmethod->getlasterror()); progname, fn, stream->walmethod->getlasterror());
return false; return false;
} }
...@@ -1121,7 +1121,7 @@ ProcessXLogDataMsg(PGconn *conn, StreamCtl *stream, char *copybuf, int len, ...@@ -1121,7 +1121,7 @@ ProcessXLogDataMsg(PGconn *conn, StreamCtl *stream, char *copybuf, int len,
if (xlogoff != 0) if (xlogoff != 0)
{ {
fprintf(stderr, fprintf(stderr,
_("%s: received transaction log record for offset %u with no file open\n"), _("%s: received write-ahead log record for offset %u with no file open\n"),
progname, xlogoff); progname, xlogoff);
return false; return false;
} }
......
...@@ -282,7 +282,7 @@ RunIdentifySystem(PGconn *conn, char **sysid, TimeLineID *starttli, ...@@ -282,7 +282,7 @@ RunIdentifySystem(PGconn *conn, char **sysid, TimeLineID *starttli,
if (sscanf(PQgetvalue(res, 0, 2), "%X/%X", &hi, &lo) != 2) if (sscanf(PQgetvalue(res, 0, 2), "%X/%X", &hi, &lo) != 2)
{ {
fprintf(stderr, fprintf(stderr,
_("%s: could not parse transaction log location \"%s\"\n"), _("%s: could not parse write-ahead log location \"%s\"\n"),
progname, PQgetvalue(res, 0, 2)); progname, PQgetvalue(res, 0, 2));
PQclear(res); PQclear(res);
......
...@@ -434,7 +434,7 @@ main(int argc, char *argv[]) ...@@ -434,7 +434,7 @@ main(int argc, char *argv[])
if (ControlFile.state != DB_SHUTDOWNED && !force) if (ControlFile.state != DB_SHUTDOWNED && !force)
{ {
printf(_("The database server was not shut down cleanly.\n" printf(_("The database server was not shut down cleanly.\n"
"Resetting the transaction log might cause data to be lost.\n" "Resetting the write-ahead log might cause data to be lost.\n"
"If you want to proceed anyway, use -f to force reset.\n")); "If you want to proceed anyway, use -f to force reset.\n"));
exit(1); exit(1);
} }
...@@ -447,7 +447,7 @@ main(int argc, char *argv[]) ...@@ -447,7 +447,7 @@ main(int argc, char *argv[])
KillExistingArchiveStatus(); KillExistingArchiveStatus();
WriteEmptyXLOG(); WriteEmptyXLOG();
printf(_("Transaction log reset\n")); printf(_("Write-ahead log reset\n"));
return 0; return 0;
} }
...@@ -1159,7 +1159,7 @@ WriteEmptyXLOG(void) ...@@ -1159,7 +1159,7 @@ WriteEmptyXLOG(void)
static void static void
usage(void) usage(void)
{ {
printf(_("%s resets the PostgreSQL transaction log.\n\n"), progname); printf(_("%s resets the PostgreSQL write-ahead log.\n\n"), progname);
printf(_("Usage:\n %s [OPTION]... DATADIR\n\n"), progname); printf(_("Usage:\n %s [OPTION]... DATADIR\n\n"), progname);
printf(_("Options:\n")); printf(_("Options:\n"));
printf(_(" -c XID,XID set oldest and newest transactions bearing commit timestamp\n")); printf(_(" -c XID,XID set oldest and newest transactions bearing commit timestamp\n"));
...@@ -1167,7 +1167,7 @@ usage(void) ...@@ -1167,7 +1167,7 @@ usage(void)
printf(_(" [-D] DATADIR data directory\n")); printf(_(" [-D] DATADIR data directory\n"));
printf(_(" -e XIDEPOCH set next transaction ID epoch\n")); printf(_(" -e XIDEPOCH set next transaction ID epoch\n"));
printf(_(" -f force update to be done\n")); printf(_(" -f force update to be done\n"));
printf(_(" -l XLOGFILE force minimum WAL starting location for new transaction log\n")); printf(_(" -l WALFILE force minimum WAL starting location for new write-ahead log\n"));
printf(_(" -m MXID,MXID set next and oldest multitransaction ID\n")); printf(_(" -m MXID,MXID set next and oldest multitransaction ID\n"));
printf(_(" -n no update, just show what would be done (for testing)\n")); printf(_(" -n no update, just show what would be done (for testing)\n"));
printf(_(" -o OID set next OID\n")); printf(_(" -o OID set next OID\n"));
......
...@@ -80,7 +80,7 @@ rewind_parseTimeLineHistory(char *buffer, TimeLineID targetTLI, int *nentries) ...@@ -80,7 +80,7 @@ rewind_parseTimeLineHistory(char *buffer, TimeLineID targetTLI, int *nentries)
if (nfields != 3) if (nfields != 3)
{ {
fprintf(stderr, _("syntax error in history file: %s\n"), fline); fprintf(stderr, _("syntax error in history file: %s\n"), fline);
fprintf(stderr, _("Expected a transaction log switchpoint location.\n")); fprintf(stderr, _("Expected a write-ahead log switchpoint location.\n"));
exit(1); exit(1);
} }
if (entries && tli <= lasttli) if (entries && tli <= lasttli)
......
...@@ -680,7 +680,7 @@ XLogDumpDisplayStats(XLogDumpConfig *config, XLogDumpStats *stats) ...@@ -680,7 +680,7 @@ XLogDumpDisplayStats(XLogDumpConfig *config, XLogDumpStats *stats)
static void static void
usage(void) usage(void)
{ {
printf(_("%s decodes and displays PostgreSQL transaction logs for debugging.\n\n"), printf(_("%s decodes and displays PostgreSQL write-ahead logs for debugging.\n\n"),
progname); progname);
printf(_("Usage:\n")); printf(_("Usage:\n"));
printf(_(" %s [OPTION]... [STARTSEG [ENDSEG]]\n"), progname); printf(_(" %s [OPTION]... [STARTSEG [ENDSEG]]\n"), progname);
......
/* /*
* xlog.h * xlog.h
* *
* PostgreSQL transaction log manager * PostgreSQL write-ahead log manager
* *
* Portions Copyright (c) 1996-2017, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2017, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
......
/* /*
* xlog_internal.h * xlog_internal.h
* *
* PostgreSQL transaction log internal declarations * PostgreSQL write-ahead log internal declarations
* *
* NOTE: this file is intended to contain declarations useful for * NOTE: this file is intended to contain declarations useful for
* manipulating the XLOG files directly, but it is not supposed to be * manipulating the XLOG files directly, but it is not supposed to be
......
/* /*
* xlogdefs.h * xlogdefs.h
* *
* Postgres transaction log manager record pointer and * Postgres write-ahead log manager record pointer and
* timeline number definitions * timeline number definitions
* *
* Portions Copyright (c) 1996-2017, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2017, PostgreSQL Global Development Group
......
...@@ -483,7 +483,7 @@ sub append_conf ...@@ -483,7 +483,7 @@ sub append_conf
=item $node->backup(backup_name) =item $node->backup(backup_name)
Create a hot backup with B<pg_basebackup> in subdirectory B<backup_name> of Create a hot backup with B<pg_basebackup> in subdirectory B<backup_name> of
B<< $node->backup_dir >>, including the transaction logs. Transaction logs are B<< $node->backup_dir >>, including the WAL. WAL files
fetched at the end of the backup, not streamed. fetched at the end of the backup, not streamed.
You'll have to configure a suitable B<max_wal_senders> on the You'll have to configure a suitable B<max_wal_senders> on the
...@@ -507,7 +507,7 @@ sub backup ...@@ -507,7 +507,7 @@ sub backup
=item $node->backup_fs_hot(backup_name) =item $node->backup_fs_hot(backup_name)
Create a backup with a filesystem level copy in subdirectory B<backup_name> of Create a backup with a filesystem level copy in subdirectory B<backup_name> of
B<< $node->backup_dir >>, including transaction logs. B<< $node->backup_dir >>, including WAL.
Archiving must be enabled, as B<pg_start_backup()> and B<pg_stop_backup()> are Archiving must be enabled, as B<pg_start_backup()> and B<pg_stop_backup()> are
used. This is not checked or enforced. used. This is not checked or enforced.
...@@ -525,7 +525,7 @@ sub backup_fs_hot ...@@ -525,7 +525,7 @@ sub backup_fs_hot
=item $node->backup_fs_cold(backup_name) =item $node->backup_fs_cold(backup_name)
Create a backup with a filesystem level copy in subdirectory B<backup_name> of Create a backup with a filesystem level copy in subdirectory B<backup_name> of
B<< $node->backup_dir >>, including transaction logs. The server must be B<< $node->backup_dir >>, including WAL. The server must be
stopped as no attempt to handle concurrent writes is made. stopped as no attempt to handle concurrent writes is made.
Use B<backup> or B<backup_fs_hot> if you want to back up a running server. Use B<backup> or B<backup_fs_hot> if you want to back up a running server.
......
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