pg_freespacemap模块提供了一种检查空闲空间映射(FSM)的方法。 它提供了一个名为pg_freespace的函数,更准确地说,是两个重载函数。 这些函数显示FSM中为给定页面或关系中所有页面记录的值。
默认情况下,只有超级用户以及拥有pg_stat_scan_tables角色权限的角色才能使用。 可以使用GRANT向其他用户授予访问权限。
存储在空闲空间映射中的值并不精确。它们会被舍入到BLCKSZ的 1/256 精度(在默认 BLCKSZ 下为 32 字节),并且不会随着元组的插入和更新而完全保持最新。
对于索引,被跟踪的是完全未使用的页面,而不是页面内部的空闲空间。因此,这些值本身并无实际意义,只能表明某个页面是在用还是为空。
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)
最初版本由 Mark Kirkwood <markir@paradise.net.nz> 编写。 在 8.4 版中,Heikki Linnakangas <heikki@enterprisedb.com> 为适应新的FSM实现对其进行了重写。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。