Re: Add “FOR UPDATE NOWAIT” lock details to the log.

From: Yuki Seino <seinoyu(at)oss(dot)nttdata(dot)com>
To: Jelte Fennema-Nio <postgres(at)jeltef(dot)nl>, Fujii Masao <masao(dot)fujii(at)oss(dot)nttdata(dot)com>
Cc: pgsql-hackers(at)lists(dot)postgresql(dot)org
Subject: Re: Add “FOR UPDATE NOWAIT” lock details to the log.
Date: 2025-02-18 09:33:11
Message-ID: d9402045-d532-451d-b17e-0d02b0488197@oss.nttdata.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers


On 2025/02/13 2:31, Jelte Fennema-Nio wrote:
> On Wed, 12 Feb 2025 at 12:32, Fujii Masao<masao(dot)fujii(at)oss(dot)nttdata(dot)com> wrote:
>>> What do you think if we simply don't log anything for SKIP LOCKED?
>> Implementing both NOWAIT and SKIP LOCKED could take time and make the patch
>> more complex. I'm fine with focusing on the NOWAIT case first as an initial patch.
> I think that makes sense. It's a fairly common pattern to use SKIP
> LOCKED to implement a concurrent job queue. Having such a usecase
> suddenly create lots of logs seems undesirable, especially since it
> created no logs at all before. Since NOWAIT already results in an
> error (and thus a log), having it add some additional info seems
> totally reasonable.

Thank you for the advice. For now, my goal is to output only NOWAIT.
Since lock.c cannot reference LockWaitPolicy, I believe we need to
extend the IF conditions in LockAcquire, LockAcquireExtended, and their
higher-level functions. This could be a pretty significant modification.
I’ll think about whether there’s a better approach. I welcome any good
ideas from everyone too. As an aside, I also noticed that
dontWait(=true) is routed not only from NOWAIT and SKIP LOCKED but also
from vacuum and other parts. do_autovacuum(autovacuum.c) ->
ConditionalLockDatabaseObject -> LockAcquireExtended Regards,

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Dmitry Dolgov 2025-02-18 09:36:36 Re: pg_stat_statements and "IN" conditions
Previous Message Jelte Fennema-Nio 2025-02-18 09:29:35 Always show correct error message for statement timeouts, fixes random buildfarm failures