29.1. 确定磁盘使用率

每个表都有一个主堆磁盘文件,其中存储了大多数数据。如果表中的任何列具有潜在的宽值,则可能还会有一个与该表关联的 TOAST 文件,该文件用于存储太宽而无法舒适地容纳在主表中的值(请参见Section 68.2)。如果存在,则 TOAST 表上将有一个有效索引。也可能有与基表关联的索引。每个表和索引都存储在一个单独的磁盘文件中-如果文件超过 1 GB,则可能多个文件。这些文件的命名约定在Section 68.1中描述。

您可以通过三种方式监视磁盘空间:使用Table 9.84中列出的 SQL 函数,使用oid2name模块或手动检查系统目录。 SQL 函数最易于使用,通常建议使用。本节的其余部分显示如何通过检查系统目录来执行此操作。

在最近清理或分析的数据库上使用 psql,可以发出查询以查看任何表的磁盘使用情况:

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

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

每个页面通常为 8 KB。 (请记住,relpages仅由VACUUMANALYZE和一些 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 indexrelid
             FROM pg_index
             WHERE indrelid = 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