本章讨论如何观察PostgreSQL数据库系统的磁盘使用情况。 在当前的版本里,数据库管理员对磁盘存储的布局没有太多的 控制,因此本节主要是提示性的信息,并且给你一些如何用操作 系统的工具管理磁盘存储的概念。
每个表都有一个主堆的磁盘文件,大多数数据都存储在这里。要存储 长的字段值,则另外还有一个TOAST文件与这个表相关联, 其名字是基于该表的OID(实际上是pg_class.relfilenode), 以及一个在TOAST表上的索引。同时还可能有索引和这个 基表关联。
你可以从三个地方监视磁盘空间:从 psql 里使用 VACUUM 的信息,从 psql 里使用 contrib/dbsize 里面的工具,以及在命令行上使用 contrib/oid2name 里面的工具。如果 psql 和任何最近刚刚清理(或者分析过)的数据库进行联接, 那么我们可以用查询来查看任意表的磁盘使用:
SELECT relfilenode, relpages FROM pg_class WHERE relname = 'customer'; relfilenode | relpages -------------+---------- 16806 | 60 (1 row)
每个页通常都是 8 K字节。(记住,relpages只是由 VACUUM 和 ANALYZE 更新。)
要显示 TOAST 的表使用的空间,我们可以使用一个类似下面这样的查询, 替换了relfilenode即可(由上面的查询得出):
SELECT relname, relpages FROM pg_class WHERE relname = 'pg_toast_16806' OR relname = 'pg_toast_16806_index' 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
contrib/dbsize 向我们的数据库里装载一些函数,这些函数 允许我们在 psql 里找出一个表或者一个数据库的大小,而且不用 VACUUM或者 ANALYZE。
你也可以使用 oid2name 显示磁盘用量。参阅 该目录中的 README.oid2name 获取例子。它包括一个为每个 数据库显示磁盘用量的脚本。