pgsql: Handle cancel requests with PID 0 gracefully - Mailing list pgsql-committers

From Heikki Linnakangas
Subject pgsql: Handle cancel requests with PID 0 gracefully
Date
Msg-id E1ugsEd-001NGD-2W@gemulon.postgresql.org
Whole thread Raw
List pgsql-committers
Handle cancel requests with PID 0 gracefully

If the client sent a query cancel request with backend PID 0, it
tripped an assertion. With assertions disabled, you got this in the
log instead:

    LOG:  invalid cancel request with PID 0
    LOG:  wrong key in cancel request for process 0

Query cancellations don't even require authentication, so we better
tolerate bogus requests. Fix by turning the assertion into a regular
runtime check.

Spotted while testing libpq behavior with a modified server that
didn't send BackendKeyData to the client.

Backpatch-through: 18

Branch
------
REL_18_STABLE

Details
-------
https://git.postgresql.org/pg/commitdiff/fce7da1e73853b21a8084e645ac39354c1476261

Modified Files
--------------
src/backend/storage/ipc/procsignal.c | 6 +++++-
1 file changed, 5 insertions(+), 1 deletion(-)


pgsql-committers by date:

Previous
From: Tom Lane
Date:
Subject: pgsql: Don't put library-supplied -L/-I switches before user-supplied o
Next
From: Bruce Momjian
Date:
Subject: pgsql: doc PG 18 relnotes: update to current