diff options
| author | Heikki Linnakangas <heikki.linnakangas@iki.fi> | 2023-07-06 17:25:29 +0300 | 
|---|---|---|
| committer | Heikki Linnakangas <heikki.linnakangas@iki.fi> | 2023-07-06 17:29:14 +0300 | 
| commit | c50b869edad40455efc9a7287c45648d7a2715b2 (patch) | |
| tree | a2d18f9fb73830f19371f4950cbfd043d72b2c48 /src/backend/access/spgist/spgvacuum.c | |
| parent | 34f6c606356887d6f5090c92fe7247cbf7946ef0 (diff) | |
WAL-log the creation of the init fork of unlogged indexes.
We create a file, so we better WAL-log it. In practice, all the
built-in index AMs and all extensions that I'm aware of write a
metapage to the init fork, which is WAL-logged, and replay of the
metapage implicitly creates the fork too. But if ambuildempty() didn't
write any page, we would miss it.
This can be seen with dummy_index_am. Set up replication, create a
'dummy_index_am' index on an unlogged table, and look at the files
created in the replica: the init fork is not created on the
replica. Dummy_index_am doesn't do anything with the relation files,
however, so it doesn't lead to any user-visible errors.
Backpatch to all supported versions.
Reviewed-by: Robert Haas
Discussion: https://www.postgresql.org/message-id/6e5bbc08-cdfc-b2b3-9e23-1a914b9850a9%40iki.fi
Diffstat (limited to 'src/backend/access/spgist/spgvacuum.c')
0 files changed, 0 insertions, 0 deletions
