coffee_cn

博客园 首页 新随笔 联系 订阅 管理

转自:http://www.17xie.com/read-34764.html

 

章26. 监控磁盘使用情况

 

本章讨论如何观察 PostgreSQL 数据库系统的磁盘使用情况。

26.1. 判断磁盘的使用量

每个表都有一个主堆(primary heap)磁盘文件,大多数数据都存储在这里。如果一个表存在值可能会很长的字段,则另外还有一个用于存储因为数值太长而不适合存储在主表中的数据的 TOAST 文件(参阅节52.2)。如果存在这个扩展表,那么将会同时存在一个 TOAST 索引。当然,同时还可能有索引和基表关联。每个表和索引都存放在单独的磁盘文件里(超过 1GB 可能会被分割成多个)。这些文件的命名原则在节52.1里描述。

可以使用三种方法监视磁盘空间:使用表9-48中列出的 SQL 函数、使用 VACUUM 信息、在命令行上使用 contrib/oid2name 中的工具。报告普通表、带有索引和长值(TOAST)的表、数据库、表空间的信息最简单的方法是使用 SQL 函数。

在最近刚刚清理(或者分析过)的数据库上使用 psql 的话,可以使用查询来查看任意表的磁盘使用:

SELECT relfilenode, relpages FROM pg_class WHERE relname = 'customer';
relfilenode | relpages
-------------+----------
16806 |       60
(1 row)

每个页通常都是 8K 字节。注意,relpages 只被 VACUUM, ANALYZE 和几个 DDL 命令(例如 CREATE INDEX)更新。如果你想直接检查表的磁盘文件,那么可以使用 relfilenode 字段值。

要显示 TOAST 表使用的空间,我们可以使用一个类似下面这样的查询:

SELECT relname, relpages
FROM pg_class,
(SELECT reltoastrelid FROM pg_class
WHERE relname = 'customer') ss
WHERE oid = ss.reltoastrelid
OR oid = (SELECT reltoastidxid FROM pg_class
WHERE oid = 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_indexdex |       26

很容易用下面的信息找出最大的表和索引:

SELECT relname, relpages FROM pg_class ORDER BY relpages DESC;
relname        | relpages
----------------------+----------
bigtable             |     3290
customer             |     3144

还可以使用 contrib/oid2name 显示磁盘用量,参见该目录中的 README.oid2name 文件以获取示例,它包括一个为每个数据库显示磁盘用量的脚本。

26.2. 磁盘满导致的失效

一个数据库管理员最重要的磁盘监控任务就是确保磁盘不会写满。磁盘写满可能不会导致数据的丢失,但它肯定会导致系统进一步使用的问题。如果 WAL 文件也在同一个磁盘上(缺省配置就是这样),则会发生数据库服务器恐慌,并且停止运行。

如果你不能通过删除其它东西来释放磁盘空间,那么你可以通过使用表空间把一些数据库文件移动到其它文件系统上去。参阅节19.6获取更多信息。

【提示】有些文件系统在快要写满的时候性能会急剧恶化,因此不要等到磁盘完全写满时才采取行动。

如果你的系统支持针对每个用户的磁盘限额,那么数据库自然也将受制于此,超过限额的影响和完全用光磁盘是完全一样的。

posted on 2008-07-31 16:21  coffee  阅读(500)  评论(0)    收藏  举报