28.1. 判断磁盘的使用量

每个表都有一个主堆(primary heap)磁盘文件,大多数数据都存储在这里。 如果一个表存在值可能会很长的字段,则另外还有一个用于存储因为数值 太长而不适合存储在主表中的数据的TOAST文件(参阅Section 54.2)。如果存在这个扩展表,那么将会同时存在 一个TOAST索引。当然,同时还可能有索引和基表关联。每 个表和索引都存放在单独的磁盘文件里(超过 1GB 可能会被分割成多个)。 这些文件的命名原则在Section 54.1里描述。

可以使用三种方法监视磁盘空间:使用Table 9-58 中列出的SQL函数、使用contrib/oid2name中的工具或者使用系统目 录中的手动检查。SQL函数是用起来最简单并且通常是被推荐使用的。 contrib/oid2nameSection F.19中被描述。 这部分的剩余部分展示了如何通过系统目录检查来做。

在最近刚刚清理(或者分析过)的数据库上使用psql的话, 可以使用查询来查看任意表的磁盘使用:

SELECT pg_relation_filepath(oid), relpages FROM pg_class WHERE relname = 'customer';

 pg_relation_filepath | relpages 
----------------------+----------
 base/16384/16806     |       60
(1 row)

每个页通常都是8K字节。(注意,relpages只被VACUUM, ANALYZE和几个DDL命令(例如CREATE INDEX)更新。如果你想 直接检查表的磁盘文件,那么可以关注文件的路径名。

要显示TOAST表使用的空间,我们可以使用一个类似下面这样的查询:

SELECT relname, relpages
FROM pg_class,
     (SELECT reltoastrelid
      FROM pg_class
      WHERE relname = 'customer') AS ss
WHERE oid = ss.reltoastrelid OR
      oid = (SELECT reltoastidxid
             FROM pg_class
             WHERE oid = ss.reltoastrelid)
ORDER BY relname;

       relname        | relpages 
----------------------+----------
 pg_toast_16806       |        0
 pg_toast_16806_index |        1

也可以很容易地显示索引的尺寸:

SELECT c2.relname, c2.relpages
FROM pg_class c, pg_class c2, pg_index i
WHERE c.relname = 'customer' AND
      c.oid = i.indrelid AND
      c2.oid = i.indexrelid
ORDER BY c2.relname;

       relname        | relpages 
----------------------+----------
 customer_id_indexdex |       26

很容易用下面的信息找出最大的表和索引:

SELECT relname, relpages
FROM pg_class
ORDER BY relpages DESC;

       relname        | relpages 
----------------------+----------
 bigtable             |     3290
 customer             |     3144