Re: [HACKERS] WAL logging problem in 9.4.3? - Mailing list pgsql-hackers

From Heikki Linnakangas
Subject Re: [HACKERS] WAL logging problem in 9.4.3?
Date
Msg-id df32e286-ae2b-f45a-8f2e-4fa02684300b@iki.fi
Whole thread Raw
In response to Re: [HACKERS] WAL logging problem in 9.4.3?  (Michael Paquier <michael@paquier.xyz>)
Responses Re: [HACKERS] WAL logging problem in 9.4.3?
List pgsql-hackers
Thanks for picking this up!

(I hope this gets through the email filters this time, sending a shell 
script seems to be difficult. I also trimmed the CC list, if that helps.)

On 04/07/18 07:59, Michael Paquier wrote:
> Hence I propose the patch attached which disables the TRUNCATE and COPY
> optimizations for two cases, which are the ones actually causing
> problems.  One solution has been presented by Simon here for COPY, which
> is to disable the optimization when there are no blocks on a relation
> with wal_level = minimal:
> https://www.postgresql.org/message-id/CANP8+jKN4V4MJEzFN_iEtdZ+1oM=YETxvmuu1YK4UMXQY2gaGw@mail.gmail.com
> For back-patching, I find that really appealing.

This fails in the case that there are any WAL-logged changes to the 
table while the COPY is running. That can happen at least if the table 
has an INSERT trigger, that performs operations on the same table, and 
the COPY fires the trigger. That scenario is covered by the little bash 
script I posted earlier in this thread 
(https://www.postgresql.org/message-id/55AFC302.1060805%40iki.fi). 
Attached is a new version of that script, updated to make it work with v11.

> The second thing that the patch attached does is to tweak
> ExecuteTruncateGuts so as the TRUNCATE optimization never runs for
> wal_level = minimal.

If we go down that route, let's at least keep the TRUNCATE optimization 
for temporary and unlogged tables.

- Heikki


Attachment

pgsql-hackers by date:

Previous
From: Tom Lane
Date:
Subject: Re: [PG-11] Potential bug related to INCLUDE clause of CREATE INDEX
Next
From: Dilip Kumar
Date:
Subject: Re: [PG-11] Potential bug related to INCLUDE clause of CREATE INDEX