From: Michael Paquier Date: Wed, 9 Oct 2019 04:31:38 +0000 (+0900) Subject: Flush logical mapping files with fd opened for read/write at checkpoint X-Git-Tag: REL9_4_25~31 X-Git-Url: http://git.postgresql.org/gitweb/?a=commitdiff_plain;h=59800f7cef558da424a98ee4b9c74a0dd2758ea5;p=postgresql.git Flush logical mapping files with fd opened for read/write at checkpoint The file descriptor was opened with read-only to fsync a regular file, which would cause EBADFD errors on some platforms. This is similar to the recent fix done by a586cc4b (which was broken by me with 82a5649), except that I noticed this issue while monitoring the backend code for similar mistakes. Backpatch to 9.4, as this has been introduced since logical decoding exists as of b89e151. Author: Michael Paquier Reviewed-by: Andres Freund Discussion: https://postgr.es/m/20191006045548.GA14532@paquier.xyz Backpatch-through: 9.4 --- diff --git a/src/backend/access/heap/rewriteheap.c b/src/backend/access/heap/rewriteheap.c index f70b2f32055..b72dff8e4e7 100644 --- a/src/backend/access/heap/rewriteheap.c +++ b/src/backend/access/heap/rewriteheap.c @@ -1280,7 +1280,8 @@ CheckPointLogicalRewriteHeap(void) } else { - int fd = OpenTransientFile(path, O_RDONLY | PG_BINARY, 0); + /* on some operating systems fsyncing a file requires O_RDWR */ + int fd = OpenTransientFile(path, O_RDWR | PG_BINARY, 0); /* * The file cannot vanish due to concurrency since this function