本节讨论如何监控 PostgreSQL 数据库系统的磁盘使用情况。
每个表都有一个主要的堆磁盘文件,其中存储了大部分数据。如果表中包含任何具有潜在宽值的列,还可能有一个TOAST与表相关联的文件,用于存储过大而无法舒适地放入主表中的值(参见 第 65.2 节)。如果存在,将有一个有效的索引在TOAST表上。还可能存在与基本表关联的索引。每个表和索引都存储在单独的磁盘文件中——如果文件超过 1 GB,可能不止一个文件。这些文件的命名约定在 第 65.1 节 中描述。
您可以通过三种方式监控磁盘空间:使用 表 9.100 中列出的 SQL 函数,使用 oid2name 模块,或手动检查系统目录。SQL 函数最易使用,通常建议使用。本节的其余部分将介绍如何通过检查系统目录来实现。
在最近进行了 VACUUM 或 ANALYZE 的数据库上使用 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
仅由 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 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_index | 26
使用这些信息可以轻松找到最大的表和索引
SELECT relname, relpages FROM pg_class ORDER BY relpages DESC; relname | relpages ----------------------+---------- bigtable | 3290 customer | 3144
如果您在文档中发现任何不正确的内容,与您对特定功能的体验不符,或者需要进一步澄清,请使用 此表格 报告文档问题。