贝利信息

postgresql索引文件结构如何设计_postgresql索引文件格式

日期:2025-11-25 00:00 / 作者:舞姬之光
PostgreSQL默认使用B-tree索引,基于8KB页组织,采用多层树结构,包含根、内部和叶节点,叶子节点同层且双向链接。页由页头、元组数组、空闲空间和特殊区域组成,页头含LSN、校验和等信息,元组存储键值与TID,支持压缩。插入删除触发分裂或清理,WAL保障一致性,结构统一支持多种索引类型。

PostgreSQL 使用 B-tree 作为默认索引类型,其索引文件结构基于磁盘页(Page)组织,每个页大小通常为 8KB。整个索引结构以多层级的树形方式存储,支持高效查找、插入和删除操作。

B-tree 索引整体结构

PostgreSQL 的 B-tree 索引由多个逻辑层级组成:根节点(Root)、中间节点(Internal Nodes)和叶节点(Leaf Nodes)。数据按键值有序排列,所有叶子节点位于同一层,并通过双向链表连接,便于范围扫描。

索引页(Index Page)格式

每个索引页遵循统一的底层结构,由页头、元数据、元组数组和空闲空间组成。

页头信息(PageHeaderData): 元组数组区: 空闲空间: 特殊区域(Special Section):

索引项(IndexTuple)结构细节

在 B-tree 中,IndexTuple 是基本存储单元,定义在 itup.h 中。

构建与维护机制

索引不是实时完全平衡的,而是通过写时复制(Copy-on-Write)和 WAL 日志保证一致性。

基本上就这些。PostgreSQL 的索引文件设计兼顾性能与可靠性,利用固定页结构和清晰的层次划分,实现高效的磁盘I/O和并发控制。