| From: | Bruce Momjian <bruce(at)momjian(dot)us> | 
|---|---|
| To: | Michael Renner <michael(dot)renner(at)amd(dot)co(dot)at> | 
| Cc: | PostgreSQL-development <pgsql-hackers(at)postgresql(dot)org> | 
| Subject: | Re: Documentation Update: WAL & Checkpoints | 
| Date: | 2009-04-09 16:22:52 | 
| Message-ID: | 200904091622.n39GMqQ00435@momjian.us | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-hackers | 
Michael Renner wrote:
> Hi,
> 
> this is a small update to the first paragraph of the WAL configuration 
> chapter, going into more detail WRT redo vs. checkpoint records, since 
> the underlying behavior is currently only deducible from the source. I'm 
> not perfectly sure if I got everything right, so feel free to change as 
> necessary.
> 
> I think it'd be more appropriate to split the chapter and separate 
> basics from implementation details and tuneables, but for time being 
> this ought to suffice. Is somebody "in charge" of the documentation and 
> overall structure or is it a community effort as everything else?
> 
I read over you patch and I was afraid it was trying to put too much
information into a single paragraph, so I added a second paragraph that
just talks about checkpoint smoothing.  I did not address the issue of
when the REDO WAL entry is written --- that is probably too much detail
for our documentation.
New patch attached, and applied.
---------------------------------------------------------------------------
> 
> Best regards,
> Michael Renner
> diff --git a/doc/src/sgml/wal.sgml b/doc/src/sgml/wal.sgml
> index cff6fde..69b8b0a 100644
> --- a/doc/src/sgml/wal.sgml
> +++ b/doc/src/sgml/wal.sgml
> @@ -322,19 +322,24 @@
>    </para>
>  
>    <para>
> -   <firstterm>Checkpoints</firstterm><indexterm><primary>checkpoint</></>
> -   are points in the sequence of transactions at which it is guaranteed
> -   that the data files have been updated with all information written before
> -   the checkpoint.  At checkpoint time, all dirty data pages are flushed to
> -   disk and a special checkpoint record is written to the log file.
> -   In the event of a crash, the crash recovery procedure looks at the latest
> -   checkpoint record to determine the point in the log (known as the redo
> -   record) from which it should start the REDO operation.  Any changes made to
> -   data files before that point are known to be already on disk.  Hence, after
> -   a checkpoint has been made, any log segments preceding the one containing
> -   the redo record are no longer needed and can be recycled or removed. (When
> -   <acronym>WAL</acronym> archiving is being done, the log segments must be
> -   archived before being recycled or removed.)
> +   <firstterm>Checkpoints</firstterm><indexterm><primary>checkpoint</></> are
> +   points in the logical sequence of transactions at which it is guaranteed
> +   that the data files have been updated with all information created before
> +   the start of the checkpoint command.  Since flushing all dirty data (meaning
> +   "changed only in the WAL") to disk can take a while on databases with
> +   write-heavy loads, checkpoints are not a single operation but rather a
> +   series of events.  When a checkpoint starts, a redo record is written to the
> +   WAL and PostgreSQL starts writing out dirty data which has accumulated up to
> +   the redo record.  At checkpoint completion time, all changed files are
> +   fsynced and a special checkpoint record is written to the log file. In the
> +   event of a crash, the crash recovery procedure looks at the latest
> +   checkpoint record to determine from which redo record it should start the
> +   REDO operation.  Any changes made to data files before that point are known
> +   to be already on disk.  Hence, after a checkpoint has been made, any log
> +   segments preceding the one containing the redo record are no longer needed
> +   and can be recycled or removed. (When <acronym>WAL</acronym> archiving is
> +   being done, the log segments must be archived before being recycled or
> +   removed.)
>    </para>
>  
>    <para>
> 
> -- 
> Sent via pgsql-hackers mailing list (pgsql-hackers(at)postgresql(dot)org)
> To make changes to your subscription:
> http://www.postgresql.org/mailpref/pgsql-hackers
-- 
  Bruce Momjian  <bruce(at)momjian(dot)us>        http://momjian.us
  EnterpriseDB                             http://enterprisedb.com
  + If your life is a hard drive, Christ can be your backup. +
| Attachment | Content-Type | Size | 
|---|---|---|
| /rtmp/diff | text/x-diff | 3.0 KB | 
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Tom Lane | 2009-04-09 16:25:25 | Re: Strange query plan with redundant aggregate nodes | 
| Previous Message | Bruce Momjian | 2009-04-09 16:18:32 | Re: Re: [BUGS] BUG #4027: backslash escaping not disabled inplpgsql |