受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

27.6. 监控磁盘使用情况 #

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

27.6.1. 确定磁盘使用情况 #

每个表都有一个主堆磁盘文件,大部分数据都存储在那里。如果表中有任何列可能包含较宽的值,还可能有一个与该表关联的 TOAST 文件,用于存储那些不适合放在主表中的过宽值(参见Section 63.2)。如果该 TOAST 表存在,则它会有一个有效索引。基础表本身也可能带有索引。每个表和索引都存储在单独的磁盘文件中;如果某个文件会超过 1 GB,则可能拆分为多个文件。关于这些文件的命名规则,请参见Section 63.1

你可以通过三种方式监控磁盘空间:使用Table 9.94中列出的 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 文件的磁盘被写满,则数据库服务器可能会 panic 并随后关闭。

如果你无法通过删除其他文件来释放更多磁盘空间,那么可以利用表空间把部分数据库文件移动到其他文件系统上。详见Section 22.6

Tip

有些文件系统在接近写满时性能会明显变差,因此不要等到磁盘完全写满才采取措施。

如果你的系统支持按用户设置磁盘配额,那么数据库自然也会受到运行服务器的那个用户所拥有配额的限制。超出配额会带来与磁盘空间完全耗尽相同的不良影响。

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。