pgsql: Avoid O(N^2) behavior when the standby process releases many loc - Mailing list pgsql-committers

From Tom Lane
Subject pgsql: Avoid O(N^2) behavior when the standby process releases many loc
Date
Msg-id E1mhGZ3-0001Vw-2S@gemulon.postgresql.org
Whole thread Raw
List pgsql-committers
Avoid O(N^2) behavior when the standby process releases many locks.

When replaying a transaction that held many exclusive locks on the
primary, a standby server's startup process would expend O(N^2)
effort on manipulating the list of locks.  This code was fine when
written, but commit 1cff1b95a made repetitive list_delete_first()
calls inefficient, as explained in its commit message.  Fix by just
iterating the list normally, and releasing storage only when done.
(This'd be inadequate if we needed to recover from an error occurring
partway through; but we don't.)

Back-patch to v13 where 1cff1b95a came in.

Nathan Bossart

Discussion: https://postgr.es/m/CD2F0E7F-9822-45EC-A411-AE56F14DEA9F@amazon.com

Branch
------
REL_14_STABLE

Details
-------
https://git.postgresql.org/pg/commitdiff/8424dfced790a5c2886ac33f9ce33eb57bf99f09

Modified Files
--------------
src/backend/storage/ipc/standby.c | 10 ++++++----
1 file changed, 6 insertions(+), 4 deletions(-)


pgsql-committers by date:

Previous
From: Tom Lane
Date:
Subject: pgsql: plpgsql: report proper line number for errors in variable initia
Next
From: Tom Lane
Date:
Subject: pgsql: Doc: improve README files associated with TAP tests.