本节讨论如何监控 PostgreSQL 数据库系统的磁盘使用情况。
每个表都有一个主堆磁盘文件,大部分数据都存储在那里。如果表中有任何列可能包含较宽的值,还可能有一个与该表关联的 TOAST 文件,用于存储那些不适合放在主表中的过宽值(参见Section 65.2)。如果该 TOAST 表存在,则它会有一个有效索引。基础表本身也可能带有索引。每个表和索引都存储在单独的磁盘文件中;如果某个文件会超过 1 GB,则可能拆分为多个文件。关于这些文件的命名规则,请参见Section 65.1。
你可以通过三种方式监控磁盘空间:使用Table 9.99中列出的 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
数据库管理员最重要的磁盘监控任务,是确保磁盘不会被写满。数据磁盘写满不会导致数据损坏,但可能会阻止有用的活动继续进行。如果保存 WAL 文件的磁盘被写满,则数据库服务器可能会 panic 并随后关闭。
如果你无法通过删除其他文件来释放更多磁盘空间,那么可以利用表空间把部分数据库文件移动到其他文件系统上。详见Section 22.6。
有些文件系统在接近写满时性能会明显变差,因此不要等到磁盘完全写满才采取措施。
如果你的系统支持按用户设置磁盘配额,那么数据库自然也会受到运行服务器的那个用户所拥有配额的限制。超出配额会带来与磁盘空间完全耗尽相同的不良影响。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。