Oracle AWR SQL监控指标详细解释
一般情况我们作为非DBA人士,只关注一些SQL的指标,主要指标见下图,
详细的解释见下面的描述。
SQL ordered byElapsed Time
记录了执行总和时间的TOP SQL(请注意是监控范围内该SQL的执行时间总和,而不是单次SQL执行时间 Elapsed Time = CPU Time + Wait Time)。
Elapsed Time(S): SQL语句执行用总时长,此排序就是按照这个字段进行的。注意该时间不是单个SQL跑的时间,而是监控范围内SQL执行次数的总和时间。单位时间为秒。ElapsedTime = CPU Time + Wait Time
CPU Time(s): 为SQL语句执行时CPU占用时间总时长,此时间会小于等于Elapsed Time时间。单位时间为秒。
Executions: SQL语句在监控范围内的执行次数总计。
Elap per Exec(s): 执行一次SQL的平均时间。单位时间为秒。
% Total DB Time: 为SQL的Elapsed Time时间占数据库总时间的百分比。
SQL ID: SQL语句的ID编号,点击之后就能导航到下边的SQL详细列表中,点击IE的返回可以回到当前SQL ID的地方。
SQL Module: 显示该SQL是用什么方式连接到数据库执行的,如果是用SQL*Plus或者PL/SQL链接上来的那基本上都是有人在调试程序。一般用前台应用链接过来执行的sql该位置为空。
SQL Text: 简单的sql提示,详细的需要点击SQL ID。
}SQL ordered by CPUTime:
}记录了执行占CPU时间总和时间最长的TOP SQL(请注意是监控范围内该SQL的执行占CPU时间总和,而不是单次SQL执行时间)。
}SQL ordered by Gets:
}记录了执行占总buffer gets(逻辑IO)的TOP SQL(请注意是监控范围内该SQL的执行占Gets总和,而不是单次SQL执行所占的Gets)
◦Buffer Gets 获取buffer的总数。
◦Gets per Exec 执行一次获取buffer数。
◦%Total BufferGets/ Total Buffer Gets
}SQL ordered byReads:
}记录了执行占总磁盘物理读(物理IO)的TOP SQL(请注意是监控范围内该SQL的执行占磁盘物理读总和,而不是单次SQL执行所占的磁盘物理读)。
◦Physical Reads 读取磁盘总数。
◦Reads per Exec 平均一次执行读取的磁盘数。
%Total Physical Reads/Total Disk Reads
}SQL ordered byExecutions:
}记录了按照SQL的执行次数排序的TOP SQL。该排序可以看出监控范围内的SQL执行次数。
◦Rows Processed 结果总行数
◦Rows per Exec 平均每次结果行数
}SQL ordered by ParseCalls:
}记录了SQL的软解析次数的TOP SQL。说到软解析(soft prase)和硬解析(hard prase),就不能不说一下Oracle对sql的处理过程。
◦Parse Calls 该sql软解析总次数
◦% Total Parses 该sql占总的软解析次数的百分比
}SQL ordered bySharable Memory:
}记录了SQL占用library cache的大小的TOP SQL。Sharable Mem (b):占用library cache的大小,单位是byte,列出超过1048576byte。
◦Sharable Mem (b) 该sql占用的libCache的大小
◦% Total 占library cache 的百分比
}SQL ordered byVersion Count:
}记录了SQL的打开子游标的TOP SQL,列出打开子游标大于20。
◦Version Count 打开的子游标数
}SQL ordered byCluster Wait Time:
}记录了集群的等待时间的TOP SQL
◦Cluster Wait Time (s) 等待时间
CWT % of ElapsdTime 表示等待时间/总的执行时间的百分比