本章节主要介绍PolarDB PostgreSQL版(兼容Oracle)中的不同视图详细信息,可通过查询不同视图获取相关对象信息,进而方便定位性能问题。
表
- pg_stat_all_tablespg_stat_all_tables视图将为当前数据库中的每一个表显示与该表访问相关的统计信息。相关参数说明如下表所示:
参数 类型 描述 relidoid 表OID。 schemanamename 表所在的Schema的名称。 relnamename 表名称。 seq_scanbigint 在表上发起的顺序扫描的次数。 seq_tup_readbigint 被顺序扫描取得的活着的行的数量。 idx_scanbigint 在表上发起的索引扫描的次数。 idx_tup_fetchbigint 被索引扫描取得的活着的行的数量。 n_tup_insbigint 被插入的行数。 n_tup_updbigint 被更新的行数(包括 HOT 更新的行)。 n_tup_delbigint 被删除的行数。 n_tup_hot_updbigint 被更新的 HOT 行数(即不要求独立索引更新的行更新)。 n_live_tupbigint 活着的行的估计数量。 n_dead_tupbigint 死亡行的估计数量。 n_mod_since_analyzebigint 从表最近一次被分析后被修改的行的估计数量。 last_vacuumtimestamp with time zone 最近一次表被手动清理的时间(不统计VACUUM FULL)。 last_autovacuumtimestamp with time zone 最近一次表被自动清理守护进程清理的时间。 last_analyzetimestamp with time zone 最近一次表被手动分析的时间。 last_autoanalyzetimestamp with time zone 最近一次表被自动清理守护进程分析的时间。 vacuum_countbigint 表被手工清理的次数(不统计VACUUM FULL)。 autovacuum_countbigint 表被自动清理守护进程清理的次数。 analyze_countbigint 表被手工分析的次数。 autoanalyze_countbigint 表被自动清理守护进程分析的次数。 - pg_statio_all_tablespg_statio_all_tables视图将为当前数据库中的每个表指定有关 I/O 的统计信息。相关参数说明如下表所示:
参数 类型 描述 relidoid 表的 OID。 schemanamename 表所在的Schema的名称。 relnamename 表的名称。 heap_blks_readbigint 从表读取的磁盘块数量。 heap_blks_hitbigint 在表中的缓冲区命中数量。 idx_blks_readbigint 从表上所有索引中读取的磁盘块数。 idx_blks_hitbigint 在表上的所有索引中的缓冲区命中数量。 toast_blks_readbigint 从表的 TOAST 表读取的磁盘块数。 toast_blks_hitbigint 在表的 TOAST 表中的缓冲区命中数量。 tidx_blks_readbigint 从表的 TOAST 表索引中读取的磁盘块数。 tidx_blks_hitbigint 在表的 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。如果所提供的常量值不在优化器统计信息记录的范围之内,优化器也会访问索引来检查。参数 类型 描述 relidoid 索引基表OID。 indexrelidoid 索引OID。 schemanamename 索引所在的Schema的名称。 relnamename 索引基表的名称。 indexrelnamename 索引名称。 idx_scanbigint 在索引上发起的索引扫描次数。 idx_tup_readbigint 在索引上由扫描返回的索引项数量。 idx_tup_fetchbigint 被使用索引的简单索引扫描取得的活着的表行数量。 - pg_statio_all_indexes显示当前数据库中每个索引的磁盘块读取总数和缓冲区命中总数,以及指定索引上与 I/O 有关的统计信息。相关参数说明如下:
参数 类型 描述 relidoid 索引基表的 OID。 indexrelidoid 索引OID。 schemanamename 索引所在Schema的名称。 relnamename 索引基表的名称。 indexrelnamename 索引名称。 idx_blks_readbigint 从索引读取的磁盘块数。 idx_blks_hitbigint 在索引中的缓冲区命中数量。
序列
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 | 在函数本身花费的总时间,不包括被它调用的其他函数。单位:毫秒。 |