2025年9月25日: PostgreSQL 18 发布!
支持版本: 当前 (18) / 17 / 16 / 15 / 14 / 13
开发版本: devel
不支持的版本: 12 / 11 / 10 / 9.6 / 9.5 / 9.4 / 9.3 / 9.2 / 9.1 / 9.0 / 8.4 / 8.3 / 8.2 / 8.1 / 8.0 / 7.4 / 7.3

27.6. 监控磁盘使用情况 #

本节讨论如何监控 PostgreSQL 数据库系统的磁盘使用情况。

27.6.1. 确定磁盘使用情况 #

每个表都有一个主堆磁盘文件,其中存储了大部分数据。如果表中有任何列包含可能较宽的值,也可能有一个TOAST与该表关联的文件,用于存储不适合主表中存储的过宽的值(请参阅 66.2 节)。如果存在,则该表将有一个有效的索引。TOAST该表可能还有与基础表关联的索引。每个表和索引都存储在一个单独的磁盘文件中 — 如果文件超过一吉字节,则可能不止一个文件。这些文件的命名约定在 66.1 节 中进行了描述。

您可以通过三种方式监控磁盘空间:使用 表 9.102 中列出的 SQL 函数、使用 oid2name 模块,或通过手动检查系统目录。SQL 函数最易于使用,并且通常推荐使用。本节的其余部分将介绍如何通过检查系统目录来完成此操作。

在最近执行过 VACUUMANALYZE 的数据库上使用 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_index |       26

使用这些信息,您可以轻松找到最大的表和索引

SELECT relname, relpages
FROM pg_class
ORDER BY relpages DESC;

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

27.6.2. 磁盘已满故障 #

数据库管理员最重要的磁盘监控任务是确保磁盘不会被填满。磁盘已满不会导致数据损坏,但可能会阻止有用的活动发生。如果存储 WAL 文件的磁盘已满,数据库服务器可能会崩溃并随之关闭。

如果您无法通过删除其他文件来释放磁盘上的额外空间,则可以使用表空间将部分数据库文件移动到其他文件系统。有关详细信息,请参阅 22.6 节

提示

某些文件系统在接近满时性能会下降,因此不要等到磁盘完全填满时才采取行动。

如果您的系统支持按用户磁盘配额,那么数据库自然会受到应用于运行服务器的用户配额的限制。超出配额将产生与磁盘空间完全用完相同的负面影响。

提交更正

如果您在文档中看到任何不正确、与您对特定功能的体验不符或需要进一步澄清的内容,请使用 此表单 报告文档问题。