summaryrefslogtreecommitdiff
path: root/src/backend/executor/nodeTidscan.c
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2018-07-09 19:26:19 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2018-07-09 19:26:19 -0400
commitd80ec868fa3aa61a8f2566ec0244c45a87a62e20 (patch)
treedba3b4e82cf5ddfb91516145a2ce42d2166808df /src/backend/executor/nodeTidscan.c
parentdd4e836748cec3e361e3b52243137960557a000d (diff)
Avoid emitting a bogus WAL record when recycling an all-zero btree page.
Commit fafa374f2 caused _bt_getbuf() to possibly emit a WAL record for a page that it was about to recycle. However, it failed to distinguish all-zero pages from dead pages, which is important because only the latter have valid btpo.xact values, or indeed any special space at all. Recycling an all-zero page with XLogStandbyInfoActive() enabled therefore led to an Assert failure, or to emission of a WAL record containing a bogus cutoff XID, which might lead to unnecessary query cancellations on hot standby servers. Per reports from Antonin Houska and 自己. Amit Kapila was first to propose this fix, and Robert Haas, myself, and Kyotaro Horiguchi reviewed it at various times. This is an old bug, so back-patch to all supported branches. Discussion: https://postgr.es/m/2628.1474272158@localhost Discussion: https://postgr.es/m/48875502.f4a0.1635f0c27b0.Coremail.zoulx1982@163.com
Diffstat (limited to 'src/backend/executor/nodeTidscan.c')
0 files changed, 0 insertions, 0 deletions