diff options
author | Alvaro Herrera <alvherre@alvh.no-ip.org> | 2020-04-29 18:46:42 -0400 |
---|---|---|
committer | Alvaro Herrera <alvherre@alvh.no-ip.org> | 2020-04-29 18:46:42 -0400 |
commit | 1816a1c6ffe46782eee9a16a974b4aa3f4b8457b (patch) | |
tree | 0c8c2d8e41d7b7d7a3f038498fa59cc0fbd36e3a /src/backend/utils/adt/jsonpath_exec.c | |
parent | fef819ac534d6efb9608fa0bbb93c6fe6c87440e (diff) | |
download | postgresql-1816a1c6ffe46782eee9a16a974b4aa3f4b8457b.tar.gz postgresql-1816a1c6ffe46782eee9a16a974b4aa3f4b8457b.zip |
Fix checkpoint signalling
Checkpointer uses its MyLatch to wake up when a checkpoint request is
received. But before commit c6550776394e the latch was not used for
anything else, so the code could just go to sleep after each loop
without rechecking the sleeping condition. That commit added a separate
ResetLatch in its code path[1], which can cause a checkpoint to go
unnoticed for potentially a long time.
Fix by skipping sleep if any checkpoint flags are set. Also add a test
to verify this; authored by Kyotaro Horiguchi.
[1] CreateCheckPoint -> InvalidateObsoleteReplicationSlots ->
ConditionVariableTimeSleep
Report and diagnosis by Kyotaro Horiguchi.
Co-authored-by: Kyotaro Horiguchi <horikyota.ntt@gmail.com>
Co-authored-by: Álvaro Herrera <alvherre@alvh.no-ip.org>
Discussion: https://postgr.es/m/20200408.141956.891237856186513376.horikyota.ntt@gmail.com
Diffstat (limited to 'src/backend/utils/adt/jsonpath_exec.c')
0 files changed, 0 insertions, 0 deletions