监控PostgreSQL的磁盘使用

每个表都有一个主要的堆磁盘文件,大多数数据都存储在其中。如果一个表有着可能会很宽(尺寸大)的列, 则另外还有一个TOAST文件与这个表相关联, 它用于存储因为太宽而不能存储在主表里面的值。如果有这个附属文件,那么TOAST表上会有一个可用的索引。 当然,同时还可能有索引和基表关联。每个表和索引都存放在单独的磁盘文件里,如果文件超过 1G 字节,甚至可能多于一个文件。
你可以以三种方式监视磁盘空间:使用SQL函数、使用oid2name模块或者人工观察系统目录。SQL函数是最容易使用的方法,同时也是通常推荐的方法。
在一个最近清理过或者分析过的数据库上使用psql,你可以发出查询来查看任意表的磁盘用量:

postgres=# SELECT pg_relation_filepath(oid), relpages FROM pg_class WHERE relname = 'ctetest';
 pg_relation_filepath | relpages 
----------------------+----------
 base/12330/41502     |     8334
(1 row)

每个页通常都是 8K 字节(记住,relpages只会由VACUUM、ANALYZE和少数几个 DDL 命令如CREATE INDEX所更新)。
显示TOAST表使用的空间:

postgres=# SELECT relname, relpages                                      
           FROM pg_class,
                (SELECT reltoastrelid
                 FROM pg_class
                 WHERE relname = 'ctetest') AS ss
           WHERE oid = ss.reltoastrelid OR
                 oid = (SELECT indexrelid
                        FROM pg_index
                        WHERE indrelid = ss.reltoastrelid)
           ORDER BY relname;
       relname        | relpages 
----------------------+----------
 pg_toast_41502       |        0
 pg_toast_41502_index |        1
(2 rows)

显示索引的尺寸:

postgres=# SELECT c2.relname, c2.relpages                       
           FROM pg_class c, pg_class c2, pg_index i
           WHERE c.relname = 'ctetest' AND
                 c.oid = i.indrelid AND
                 c2.oid = i.indexrelid
           ORDER BY c2.relname;
    relname     | relpages 
----------------+----------
 ctetest_id_idx |     2198
(1 row)

找出最大的表和索引:

postgres=# SELECT relname, relpages
           FROM pg_class
           ORDER BY relpages DESC;
                  relname                  | relpages 
-------------------------------------------+----------
 test02                                    |    39216
 ctetest                                   |     8334
 foo                                       |     4425

 

By Kalath

你可能感兴趣的:(PostgreSQL,Highgo,DB)