受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

F.27. pg_freespacemap #

pg_freespacemap模块提供了一种检查空闲空间映射FSM)的方法。 它提供了一个名为pg_freespace的函数,更准确地说,是两个重载函数。 这些函数显示空闲空间映射中针对给定页面,或关系中所有页面记录的值。

默认情况下,只有超级用户以及具有pg_stat_scan_tables角色权限的角色才能使用。 可以使用GRANT向其他用户授予访问权限。

F.27.1. 函数 #

pg_freespace(rel regclass IN, blkno bigint IN) returns int2

返回该关系中由blkno指定页面上按FSM记录的空闲空间量。

pg_freespace(rel regclass IN, blkno OUT bigint, avail OUT int2)

显示该关系中每个页面上按FSM记录的空闲空间量。返回一组 (blkno bigint, avail int2) 元组,其中关系中的每个页面对应一个元组。

存储在空闲空间映射中的值并不精确。它们会被舍入到BLCKSZ的 1/256 精度(在默认 BLCKSZ 下为 32 字节),并且不会随着元组的插入和更新而完全保持最新。

对于索引,被跟踪的是完全未使用的页面,而不是页面内部的空闲空间。因此,这些值本身并无实际意义,只能表明某个页面是在用还是为空。

F.27.2. 示例输出 #

postgres=# SELECT * FROM pg_freespace('foo');
 blkno | avail
-------+-------
     0 |     0
     1 |     0
     2 |     0
     3 |    32
     4 |   704
     5 |   704
     6 |   704
     7 |  1216
     8 |   704
     9 |   704
    10 |   704
    11 |   704
    12 |   704
    13 |   704
    14 |   704
    15 |   704
    16 |   704
    17 |   704
    18 |   704
    19 |  3648
(20 rows)

postgres=# SELECT * FROM pg_freespace('foo', 7);
 pg_freespace
--------------
         1216
(1 row)

F.27.3. 作者 #

最初版本由 Mark Kirkwood 编写。 在 8.4 版中,Heikki Linnakangas 为适应新的FSM实现对其进行了重写。

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。