GS_WLM_SESSION_QUERY_INFO_ALL
GS_WLM_SESSION_QUERY_INFO_ALL系统表显示当前数据库实例执行作业结束后的负载管理记录。此数据是从内核中转储到系统表中的数据。当设置GUC参数enable_resource_record为on时,系统会定时(周期为3分钟)将内核中query信息导入GS_WLM_SESSION_QUERY_INFO_ALL系统表。查询该系统表需要sysadmin权限,且仅在数据库postgres下面查询时有数据。
表 1 GS_WLM_SESSION_QUERY_INFO_ALL字段
名称 | 类型 | 描述 |
---|
datid | oid | 连接后端的数据库OID。 |
dbname | text | 连接后端的数据库名称。 |
schemaname | text | 模式的名称。 |
nodename | text | 语句执行的数据库实例名称。 |
username | text | 连接到后端的用户名。 |
application_name | text | 连接到后端的应用名。 |
client_addr | inet | 连接到后端的客户端的IP地址。 如果此字段是null,它表明通过服务器机器上UNIX套接字连接客户端或者这是内部进程,如autovacuum。 |
client_hostname | text | 客户端的主机名,这个字段是通过client_addr的反向DNS查找得到。这个字段只有在启动log_hostname且使用IP连接时才非空。 |
client_port | integer | 客户端用于与后端通讯的TCP端口号,如果使用Unix套接字,则为-1。 |
query_band | text | 用于标示作业类型,可通过GUC参数query_band进行设置,默认为空字符串。 |
block_time | bigint | 语句执行前的阻塞时间,包含语句解析和优化时间,单位ms。 |
start_time | timestamp with time zone | 语句执行的开始时间。 |
finish_time | timestamp with time zone | 语句执行的结束时间。 |
duration | bigint | 语句实际执行的时间,单位ms。 |
estimate_total_time | bigint | 语句预估执行时间,单位ms。 |
status | text | 语句执行结束状态:正常为finished,异常为aborted。 |
abort_info | text | 语句执行结束状态为aborted时显示异常信息。 |
resource_pool | text | 用户使用的资源池。 |
control_group | text | 语句所使用的Cgroup。 |
estimate_memory | integer | 语句估算内存大小。 |
min_peak_memory | integer | 语句在数据库实例上的最小内存峰值,单位MB。 |
max_peak_memory | integer | 语句在数据库实例上的最大内存峰值,单位MB。 |
average_peak_memory | integer | 语句执行过程中的内存使用平均值,单位MB。 |
memory_skew_percent | integer | 语句数据库实例间的内存使用倾斜率。 |
spill_info | text | 语句在数据库实例上的下盘信息: - None:数据库实例均未下盘。
- All: 数据库实例均下盘。
- [a:b]: 数量为b个数据库实例中有a个数据库实例下盘。
|
min_spill_size | integer | 若发生下盘,数据库实例上下盘的最小数据量,单位MB,默认为0。 |
max_spill_size | integer | 若发生下盘,数据库实例上下盘的最大数据量,单位MB,默认为0。 |
average_spill_size | integer | 若发生下盘,数据库实例上下盘的平均数据量,单位MB,默认为0。 |
spill_skew_percent | integer | 若发生下盘,数据库实例间下盘倾斜率。 |
min_dn_time | bigint | 语句在数据库实例上的最小执行时间,单位ms。 |
max_dn_time | bigint | 语句在数据库实例上的最大执行时间,单位ms。 |
average_dn_time | bigint | 语句在数据库实例上的平均执行时间,单位ms。 |
dntime_skew_percent | integer | 语句在数据库实例间的执行时间倾斜率。 |
min_cpu_time | bigint | 语句在数据库实例上的最小CPU时间,单位ms。 |
max_cpu_time | bigint | 语句在数据库实例上的最大CPU时间,单位ms。 |
total_cpu_time | bigint | 语句在数据库实例上的CPU总时间,单位ms。 |
cpu_skew_percent | integer | 语句在数据库实例间的CPU时间倾斜率。 |
min_peak_iops | integer | 语句在数据库实例上的每秒最小IO峰值(列存单位是次/s,行存单位是万次/s)。 |
max_peak_iops | integer | 语句在数据库实例上的每秒最大IO峰值(列存单位是次/s,行存单位是万次/s)。 |
average_peak_iops | integer | 语句在数据库实例上的每秒平均IO峰值(列存单位是次/s,行存单位是万次/s)。 |
iops_skew_percent | integer | 语句在数据库实例间的IO倾斜率。 |
warning | text | 主要显示如下几类告警信息: - Spill file size large than 256MB
- Broadcast size large than 100MB
- Early spill
- Spill times is greater than 3
- Spill on memory adaptive
- Hash table conflict
|
queryid | bigint | 语句执行使用的内部query id。 |
query | text | 执行的语句。 |
query_plan | text | 语句的执行计划。 |
node_group | text | 语句所属用户对应的逻辑数据库实例。 |
cpu_top1_node_name | text | cpu使用率第1的节点名称。 |
cpu_top2_node_name | text | cpu使用率第2的节点名称。 |
cpu_top3_node_name | text | cpu使用率第3的节点名称。 |
cpu_top4_node_name | text | cpu使用率第4的节点名称。 |
cpu_top5_node_name | text | cpu使用率第5的节点名称。 |
mem_top1_node_name | text | 内存使用量第1的节点名称。 |
mem_top2_node_name | text | 内存使用量第5的节点名称。 |
mem_top3_node_name | text | 内存使用量第5的节点名称。 |
mem_top4_node_name | text | 内存使用量第5的节点名称。 |
mem_top5_node_name | text | 内存使用量第5的节点名称。 |
cpu_top1_value | bigint | cpu使用率。 |
cpu_top2_value | bigint | cpu使用率。 |
cpu_top3_value | bigint | cpu使用率。 |
cpu_top4_value | bigint | cpu使用率。 |
cpu_top5_value | bigint | cpu使用率。 |
mem_top1_value | bigint | 内存使用量。 |
mem_top2_value | bigint | 内存使用量。 |
mem_top3_value | bigint | 内存使用量。 |
mem_top4_value | bigint | 内存使用量。 |
mem_top5_value | bigint | 内存使用量。 |
top_mem_dn | text | 内存使用量topN信息。 |
top_cpu_dn | text | cpu使用量topN信息。 |
n_returned_rows | bigint | Select返回的结果集行数。 |
n_tuples_fetched | bigint | 随机扫描行数。 |
n_tuples_returned | bigint | 顺序扫描行数。 |
n_tuples_inserted | bigint | 插入行数。 |
n_tuples_updated | bigint | 更新行数。 |
n_tuples_deleted | bigint | 删除行数。 |
n_blocks_fetched | bigint | Cache加载次数。 |
n_blocks_hit | bigint | Cache命中数。 |
db_time | bigint | 有效的DB时间花费,多线程将累加(单位:微秒)。 |
cpu_time | bigint | CPU时间(单位:微秒)。 |
execution_time | bigint | 执行器内执行时间(单位:微秒)。 |
parse_time | bigint | SQL解析时间(单位:微秒)。 |
plan_time | bigint | SQL生成计划时间(单位:微秒)。 |
rewrite_time | bigint | SQL重写时间(单位:微秒)。 |
pl_execution_time | bigint | plpgsql上的执行时间(单位:微秒)。 |
pl_compilation_time | bigint | plpgsql上的编译时间(单位:微秒)。 |
net_send_time | bigint | 网络上的时间花费(单位:微秒)。 |
data_io_time | bigint | IO上的时间花费(单位:微秒)。 |
is_slow_query | bigint | 标记是否为慢查询。 取值为1时表示其为慢查询。 |