Redrock Postgres 搜索 英文
版本: 9.3 / 9.4 / 9.5 / 9.6 / 10 / 11 / 12 / 13 / 14 / 15 / 16

13.5. 锁和索引

尽管PostgreSQL提供对表数据访问的非阻塞的读/写, 但并非所有PostgreSQL里实现的索引访问模式都能够进行非阻塞读/写。 不同的索引类型按照下面方法处理:

B-tree, GiST and SP-GiST indexes

短期的页面级共享/排他锁用于读/写访问。锁在索引行被插入/抓取后立即释放。 这种索引类型提供了无死锁条件的最高级的并发性。

Hash indexes

Hash 桶级别的共享/排他锁用于读/写访问。锁在整个 Hash 桶处理完成后释放。 Hash 桶级锁比索引级的锁提供了更好的并发性但是可能产生死锁, 因为锁持有的时间比一次索引操作时间长。

GIN indexes

短期的页面级共享/排他锁用于读/写访问。锁在索引行被插入/抓取后立即释放。 但要注意的是一个GIN索引值的插入通常导致每行几个索引键的插入, 因此GIN可能为了插入一个值而做大量的工作。

目前,B-tree 索引为并发应用提供了最好的性能。因为它还有比 Hash 索引更多的特性,在那些需要对标量数据进行索引的并发应用中,我们建议使用 B-tree 索引类型。在处理非标量类型数据的时候,B-tree 就没什么用了,应该使用 GiST, SP-GiST 或 GIN 索引。