(评论)
(comments)

原始链接: https://news.ycombinator.com/item?id=44018741

这个Hacker News帖子讨论了Pglocks.org,这是一个记录Postgres锁的资源。用户发现它很有价值,因为全面的锁信息分散在Postgres官方文档中。几位评论者强调了理解锁对于防止死锁和优化性能的重要性,尤其是在数据库迁移期间。一位用户分享了解释Postgres锁机制的相关文章链接。另一位用户推广了一个分析迁移的工具,该工具报告它们获取的锁,以便更容易地识别CI/CD期间的潜在问题。该工具旨在通过标记潜在的阻塞场景来改进迁移规划。

相关文章
  • (评论) 2025-05-15
  • 2025-05-15
  • (评论) 2025-05-16
  • (评论) 2025-05-16
  • (评论) 2025-05-17

  • 原文
    Hacker News new | past | comments | ask | show | jobs | submit login
    Pglocks.org (pglocks.org)
    79 points by hnasr 21 hours ago | hide | past | favorite | 11 comments










    Other relevant talks/blogs that I found really useful for understanding Postgres locks are:

    * Unlocking the Postgres Lock Manager by Bruce Momjian: https://momjian.us/main/writings/pgsql/locking.pdf

    * Anatomy of table-level locks by Gulcin Yildirim Jelinek: https://xata.io/blog/anatomy-of-locks



    Shameless plug: I wrote a tool[1] that executes a given migration against a test database (e.g. in your CI) and reports back what locks it acquired.

    The rationale being to have a "lock diagnostics report" commented in your PR's migration file.

    It's a prototype and has a few rough edges and missing functionality, but feedback is more than welcome.

    [1] https://github.com/agis/pglockanalyze



    Very practical! Locking is one of the things that can really bite when doing migrations.


    I'm a bit lost here.

    Locking is a challenging problem in complex systems. Is this list to be interpreted as a "TODO: get rid of locking conflicts in future releases" or more a "NOTE: be aware there are known conflicts that will not change - find ways to work around them"?

    EDIT: Also, is the creation of this list an automated or a manual effort?



    These are database locks, which means that depending which arrives first, the later transaction has to wait till the first one finishes to complete. These locks are about SQL commands and which commands can run concurrently with the others. There's a graph here of how that looks like https://pankrat.github.io/2015/django-migrations-without-dow...

    Usually for maximum performance (minimum latency, maximum throughput) you want to have operations not lock each other, unless absolutely necessary, in which case you want them to be short.



    You make it sound like the conflict is just affecting performance and won't result in a deadlock. So it's for performance aware postgres clients/users, and not for postgres developers?


    It is a guide for developers using postgres as a client, who need to write systems that don't deadlock, are performant and are correct. These are the (rather sharp) tools that postgres provides for doing so (or else you can use e.g. serializable isolation and optimistic concurrency, but in my experience that has too many false positives and bail out rather eagerly, whereas these tools let you be very precise and granular).


    The creator looks like a developer and teacher, not a Postgres core team member. So I assume this is for documentation purposes.

    I actually like this a lot, as there isn't a single place in the Postgres documentation that lists all the possible locks; it's spread out all over. Having a quick reference for what kinds of commands you'd be blocking with your transaction is valuable.

    It's pretty evident that the pages have been programmatically generated, but I'd love know what it's generated from. I think you can derive this information from the documentation, but not sure if you can do it in an automated way without an LLM.



    > there isn't a single place in the Postgres documentation that lists all the possible locks

    Did you read this page? https://www.postgresql.org/docs/current/explicit-locking.htm...



    That's a great page, but it has several issues.

    First, it isn't complete; as I said, the locking behaviour is spread out all over the Postgres documentation. For example, that page doesn't list what locks DROP INDEX takes. To find that out, you have to go to the documentation page for that command and read it carefully. In fact, really carefully — the locking behaviour is only documented under the section about CONCURRENTLY.

    The page also doesn't list what possible commands are then blocked. Locks interact in subtle (and incorrectly named!) ways that are explained in the tables on that page ("Conflicting lock modes"), so to understand if something will block something else you have to look at the two commands you are curious about and then look at how their locks interact.



    I think this is intended as educational material, not a list of things to fix.

    The locks are here by necessity, it is not so easy at all to get rid of them. And even in special cases where it is possible, the complexity you have to introduce is not to be taken lightly...

    If even a tenth of these disapppeared, it would be incredible, in a very surprising way.







    Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact



    Search:
    联系我们 contact @ memedata.com