postgres【timescaledb】--磁盘监控

打印 上一主题 下一主题

主题 858|帖子 858|积分 2574

监控磁盘空间的利用

这段内容紧张描述了数据库中表的存储方式以及如何监控磁盘空间利用情况。
监控磁盘的利用
表的存储方式



  • 每个表都有一个主堆磁盘文件,用于存储大部门数据。
  • 假如表中有任何可能具有宽值的列(即数据长度可能凌驾标准页大小的列),则可能还会有一个与表相关联的TOAST文件。TOAST文件用于存储那些太宽而无法舒服地放入主表中的值。(更多关于TOAST的具体信息拜见第73.2节)
  • 假如存在TOAST文件,它将有一个有用的索引。
  • 基础表也可能有与之关联的索引。
  • 每个表和索引都存储在单独的磁盘文件中,假如文件凌驾1GB,则可能不止一个文件。这些文件的命名约定在第73.1节中有描述。
监控磁盘空间的方法



  • 可以利用三种方式监控磁盘空间:

    • 利用表9.96中列出的SQL函数。
    • 利用oid2name模块。
    • 手动查抄系统目录。

  • SQL函数是最易于利用的方法,通常也是推荐的。
  • 接下来的部门将展示如何通过查抄系统目录来实现。
利用psql查询表的磁盘利用情况



  • 在近来举行过VACUUM或ANALYZE操纵的数据库上利用psql,可以发出查询以检察任何表的磁盘利用情况。例如,利用以下查询检察名为’customer’的表的磁盘利用情况:
    1. SELECT pg_relation_filepath(oid), relpages FROM pg_class WHERE relname = 'customer';
    复制代码
  • 查询结果会显示文件路径和占用的页数。每页通常是8KB。(注意:relpages字段只在VACUUM、ANALYZE和一些DDL命令如CREATE INDEX时更新)。
  • 假如需要直接查抄表的磁盘文件,文件路径名是有用的。
通过这些信息,可以有用地管理和监控数据库表和索引的磁盘空间利用情况。
对于timescaledb的超表利用下面的sql检察磁盘利用情况
  1. SELECT
  2.     c.relname AS table_name,
  3.     pg_relation_filepath(c.oid) AS filepath,
  4.     c.relpages AS pages
  5. FROM
  6.     pg_class c
  7. JOIN
  8.     pg_inherits i ON c.oid = i.inhrelid
  9. JOIN
  10.     pg_class parent ON parent.oid = i.inhparent
  11. WHERE
  12.     parent.relname = '你的超表';
复制代码
VACUUM和ANALYZE命令

在 PostgreSQL 中,VACUUM 和 ANALYZE 是用于维护数据库的紧张命令。以下是它们的用法及其功能:
VACUUM

VACUUM 命令用于清理数据库中的无效数据,释放空间,进步性能。
根本用法

  1. VACUUM;
复制代码


  • 效果:对当前数据库实行清理,处置惩罚全部表。
对特定表实行

  1. VACUUM my_table;
复制代码


  • 效果:仅清理指定的表。
完全清理

  1. VACUUM FULL;
复制代码


  • 效果:完全清理数据库,压缩表并释放空闲空间。这会锁定表,因此会影响其他操纵。
ANALYZE

ANALYZE 命令用于收集有关表和索引的统计信息,以资助查询优化器天生更有用的查询筹划。
根本用法

  1. ANALYZE;
复制代码


  • 效果:对当前数据库中的全部表收集统计信息。
对特定表实行

  1. ANALYZE my_table;
复制代码


  • 效果:仅对指定的表收集统计信息。
联合利用

您可以同时运行 VACUUM 和 ANALYZE,以同时清理和优化数据库:
  1. VACUUM ANALYZE;
复制代码


  • 效果:对全部表实行 VACUUM 和 ANALYZE 操纵。
总结



  • 利用 VACUUM 来清理表和释放空间。
  • 利用 ANALYZE 来更新统计信息,优化查询性能。
  • 为特定操纵选择符合的命令和选项,以最大化数据库的性能和服从。
显示由TOAST(表所占用的空间)

要显示由TOAST(The Oversized-Attribute Storage Technique)表所占用的空间,可以利用如下所示的查询语句
  1. SELECT relname, relpages
  2. FROM pg_class,
  3.      (SELECT reltoastrelid
  4.       FROM pg_class
  5.       WHERE relname = 'customer') AS ss
  6. WHERE oid = ss.reltoastrelid OR
  7.       oid = (SELECT indexrelid
  8.              FROM pg_index
  9.              WHERE indrelid = ss.reltoastrelid)
  10. ORDER BY relname;
  11.        relname        | relpages
  12. ----------------------+----------
  13. pg_toast_16806       |        0
  14. pg_toast_16806_index |        1
复制代码
检察和展示索引所占用的空间大小

  1. SELECT c2.relname, c2.relpages
  2. FROM pg_class c, pg_class c2, pg_index i
  3. WHERE c.relname = 'customer' AND
  4.       c.oid = i.indrelid AND
  5.       c2.oid = i.indexrelid
  6. ORDER BY c2.relname;
  7.       relname      | relpages
  8. -------------------+----------
  9. customer_id_index |       26
复制代码
找到你数据库中最大的表和索引

超表的话显示的是分表
  1. SELECT relname, relpages
  2. FROM pg_class
  3. ORDER BY relpages DESC;
  4.        relname        | relpages
  5. ----------------------+----------
  6. bigtable             |     3290
  7. customer             |     3144
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

麻花痒

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表