summaryrefslogtreecommitdiff
path: root/src/backend/storage/sync
diff options
context:
space:
mode:
authorMichael Paquier <michael@paquier.xyz>2021-07-20 12:12:39 +0900
committerMichael Paquier <michael@paquier.xyz>2021-07-20 12:12:39 +0900
commit7fbe0c8c4d4fe429ee1d6383706ea5ccb0f639d3 (patch)
tree4e229058647c7d5eb85dd72bbe36e50e2d90f930 /src/backend/storage/sync
parent01c3adcdd85f1507ef49bdf5430c59925d08de6f (diff)
Fix some issues with WAL segment opening for pg_receivewal --compress
The logic handling the opening of new WAL segments was fuzzy when using --compress if a partial, non-compressed, segment with the same base name existed in the repository storing those files. In this case, using --compress would cause the code to first check for the existence and the size of a non-compressed segment, followed by the opening of a new compressed, partial, segment. The code was accidentally working correctly on most platforms as the buildfarm has proved, except bowerbird where gzflush() could fail in this code path. It is wrong anyway to take the code path used pre-padding when creating a new partial, non-compressed, segment, so let's fix it. Note that this issue exists when users mix successive runs of pg_receivewal with or without compression, as discovered with the tests introduced by ffc9dda. While on it, this refactors the code so as code paths that need to know about the ".gz" suffix are down from four to one in walmethods.c, easing a bit the introduction of new compression methods. This addresses a second issue where log messages generated for an unexpected failure would not show the compressed segment name involved, which was confusing, printing instead the name of the non-compressed equivalent. Reported-by: Georgios Kokolatos Discussion: https://postgr.es/m/YPDLz2x3o1aX2wRh@paquier.xyz Backpatch-through: 10
Diffstat (limited to 'src/backend/storage/sync')
0 files changed, 0 insertions, 0 deletions