前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >数据库PostrageSQL-判断磁盘用量

数据库PostrageSQL-判断磁盘用量

作者头像
cwl_java
发布2021-01-13 15:21:30
4240
发布2021-01-13 15:21:30
举报
文章被收录于专栏:cwl_Javacwl_Java

Chapter 29. 监控磁盘使用

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

29.1. 判断磁盘用量

每个表都有一个主要的堆磁盘文件,大多数数据都存储在其中。如果一个表有着可能会很宽(尺寸大)的列, 则另外还有一个TOAST文件与这个表相关联, 它用于存储因为太宽而不能存储在主表里面的值(参阅Section 68.2)。如果有这个附属文件,那么TOAST表上会有一个可用的索引。 当然,同时还可能有索引和基表关联。每个表和索引都存放在单独的磁盘文件里 — 如果文件超过 1G 字节,甚至可能多于一个文件。这些文件的命名原则在Section 68.1中描述。

你可以以三种方式监视磁盘空间:使用Table 9.84中列出的SQL函数、使用oid2name模块或者人工观察系统目录。SQL函数是最容易使用的方法,同时也是我们通常推荐的方法。本节剩余的部分将展示如何通过观察系统目录来监视磁盘空间。

在一个最近清理过或者分析过的数据库上使用psql,你可以发出查询来查看任意表的磁盘用量:

代码语言:javascript
复制
SELECT pg_relation_filepath(oid), relpages FROM pg_class WHERE relname =
 'customer';
 pg_relation_filepath | relpages
----------------------+----------
 base/16384/16806 | 60
(1 row)

每个页通常都是 8K 字节(记住,relpages只会由VACUUM、ANALYZE和少数几个 DDL 命令如CREATE INDEX所更新)。如果你想直接检查表的磁盘文件,那么文件路径名应该有用。

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

代码语言:javascript
复制
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

你也可以很容易地显示索引的尺寸:

代码语言:javascript
复制
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
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2021-01-08 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Chapter 29. 监控磁盘使用
    • 29.1. 判断磁盘用量
    相关产品与服务
    对象存储
    对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档