本章节主要介绍PolarDB O引擎中的不同视图详细信息,可通过查询不同视图获取相关对象信息,进而方便定位性能问题。

  • pg_stat_all_tables
    pg_stat_all_tables视图将为当前数据库中的每一个表显示与该表访问相关的统计信息。相关参数说明如下表所示:
    参数 类型 描述
    relid oid 表OID。
    schemaname name 表所在的Schema的名称。
    relname name 表名称。
    seq_scan bigint 在表上发起的顺序扫描的次数。
    seq_tup_read bigint 被顺序扫描取得的活着的行的数量。
    idx_scan bigint 在表上发起的索引扫描的次数。
    idx_tup_fetch bigint 被索引扫描取得的活着的行的数量。
    n_tup_ins bigint 被插入的行数。
    n_tup_upd bigint 被更新的行数(包括 HOT 更新的行)。
    n_tup_del bigint 被删除的行数。
    n_tup_hot_upd bigint 被更新的 HOT 行数(即不要求独立索引更新的行更新)。
    n_live_tup bigint 活着的行的估计数量。
    n_dead_tup bigint 死亡行的估计数量。
    n_mod_since_analyze bigint 从表最近一次被分析后被修改的行的估计数量。
    last_vacuum timestamp with time zone 最近一次表被手动清理的时间(不统计VACUUM FULL)。
    last_autovacuum timestamp with time zone 最近一次表被自动清理守护进程清理的时间。
    last_analyze timestamp with time zone 最近一次表被手动分析的时间。
    last_autoanalyze timestamp with time zone 最近一次表被自动清理守护进程分析的时间。
    vacuum_count bigint 表被手工清理的次数(不统计VACUUM FULL)。
    autovacuum_count bigint 表被自动清理守护进程清理的次数。
    analyze_count bigint 表被手工分析的次数。
    autoanalyze_count bigint 表被自动清理守护进程分析的次数。
  • pg_statio_all_tables
    pg_statio_all_tables视图将为当前数据库中的每个表指定有关 I/O 的统计信息。相关参数说明如下表所示:
    参数 类型 描述
    relid oid 表的 OID。
    schemaname name 表所在的Schema的名称。
    relname name 表的名称。
    heap_blks_read bigint 从表读取的磁盘块数量。
    heap_blks_hit bigint 在表中的缓冲区命中数量。
    idx_blks_read bigint 从表上所有索引中读取的磁盘块数。
    idx_blks_hit bigint 在表上的所有索引中的缓冲区命中数量。
    toast_blks_read bigint 从表的 TOAST 表读取的磁盘块数。
    toast_blks_hit bigint 在表的 TOAST 表中的缓冲区命中数量。
    tidx_blks_read bigint 从表的 TOAST 表索引中读取的磁盘块数。
    tidx_blks_hit bigint 在表的 TOAST 表索引中的缓冲区命中数量。

索引

  • pg_stat_all_indexes

    通过查询pg_stat_all_indexes视图可以显示当前数据库中的每个索引访问的统计信息。

    索引可以被简单扫描、位图扫描以及通过优化器来访问。在一次位图扫描中,多个索引的输出可以通过 AND 或 OR 规则组合,当使用一次位图扫描时不能将取得的个体与特定的索引关联起来。因此,一次位图扫描会增加它使用的索引的pg_stat_all_indexes.idx_tup_read数量,并且为每个表增加pg_stat_all_tables.idx_tup_fetch数量,但是它不影响pg_stat_all_indexes.idx_tup_fetch。如果所提供的常量值不在优化器统计信息记录的范围之内,优化器也会访问索引来检查。
    参数 类型 描述
    relid oid 索引基表OID。
    indexrelid oid 索引OID。
    schemaname name 索引所在的Schema的名称。
    relname name 索引基表的名称。
    indexrelname name 索引名称。
    idx_scan bigint 在索引上发起的索引扫描次数。
    idx_tup_read bigint 在索引上由扫描返回的索引项数量。
    idx_tup_fetch bigint 被使用索引的简单索引扫描取得的活着的表行数量。
  • pg_statio_all_indexes
    显示当前数据库中每个索引的磁盘块读取总数和缓冲区命中总数,以及指定索引上与 I/O 有关的统计信息。相关参数说明如下:
    参数 类型 描述
    relid oid 索引基表的 OID。
    indexrelid oid 索引OID。
    schemaname name 索引所在Schema的名称。
    relname name 索引基表的名称。
    indexrelname name 索引名称。
    idx_blks_read bigint 从索引读取的磁盘块数。
    idx_blks_hit bigint 在索引中的缓冲区命中数量。

序列

pg_statio_all_sequences

显示当前数据库相关序列信息,以及指定序列上与 I/O 有关的统计信息。相关参数说明如下:
参数 类型 描述
relid oid 序列OID。
schemaname name 序列所在的Schema的名称。
relname name 序列名称。
blks_read bigint 从序列中读取的磁盘块数。
blks_hit bigint 在序列中的缓冲区命中数量。

函数

pg_stat_user_functions

显示被跟踪函数有关的统计信息。
参数 类型 描述
funcid oid 函数OID。
schemaname name 函数所在的Schema名称。
funcname name 函数名称。
calls bigint 函数被调用的次数。
total_time double precision 在函数以及它所调用的其他函数中花费的总时间。单位:毫秒。
self_time double precision 在函数本身花费的总时间,不包括被它调用的其他函数。单位:毫秒。