Re: Are advisory locks guaranteed to be First Come First Serve? And can the behavior be relied upon? - Mailing list pgsql-general

From Tom Lane
Subject Re: Are advisory locks guaranteed to be First Come First Serve? And can the behavior be relied upon?
Date
Msg-id 3028225.1598535873@sss.pgh.pa.us
Whole thread Raw
In response to Are advisory locks guaranteed to be First Come First Serve? And can the behavior be relied upon?  (Hemil Ruparel <hemilruparel2002@gmail.com>)
List pgsql-general
Laurenz Albe <laurenz.albe@cybertec.at> writes:
> On Thu, 2020-08-27 at 10:10 +0530, Hemil Ruparel wrote:
>> I was playing with Advisory locks. I opened three connections to the database And obtained
>> a lock with the same key. I noticed that the locks were obtained in the order of requests.
>> I was wondering whether the locks are guaranteed to be First Come First Serve and can this
>> behaviour be relied upon.

> Yes - lock requests that block are queued, with later lock requests queued behind previous
> ones.  Once a lock gets free, the first in line gets it.

> This is the same for all heavyweight locks in PostgreSQL.

There is an exception: the queue order will be rearranged if we find
that doing so is necessary to avoid a deadlock failure.  See
src/backend/storage/lmgr/README

            regards, tom lane



pgsql-general by date:

Previous
From: Susan Joseph
Date:
Subject: Re: SSL between Primary and Seconday PostgreSQL DBs
Next
From: Daniel Jakots
Date:
Subject: could not send data to client: Permission denied