Oracle 如何计算 AWR 报告中的 Sessions 数量

全网最全面的Oracle AWR 专栏,持续更新中...

在 Oracle AWR 报告的开头,有一个非常重要的指标------"Sessions",它表示对应 Snap ID 创建快照时数据库中的会话数量。

这个数值来自 DBA_HIST_SYSSTAT 视图中的统计项 "logons current"。

下面通过一个简单的实验,来看看 Oracle 是如何得到这个数值的:

SQL 复制代码
SELECT COUNT(*) FROM V$SESSION;

SELECT value FROM V$SYSSTAT WHERE NAME = 'logons current';

EXEC DBMS_WORKLOAD_REPOSITORY.CREATE_SNAPSHOT();

SELECT VALUE
FROM DBA_HIST_SYSSTAT
WHERE STAT_NAME = 'logons current'
  AND SNAP_ID = (SELECT MAX(SNAP_ID) FROM DBA_HIST_SNAPSHOT);

从实验结果可以看到,AWR 报告中的 "Sessions" 数值,实际上反映的是快照被创建时那一刻数据库中的会话数量。

它不是一个平均值,也不是一个区间内的累计值,而是一个时间点值

这一点非常值得注意:AWR 报告中大多数指标(例如 CPU、IO、Redo 等)都是区间平均或累计的结果,而 Sessions 指标则仅代表快照生成瞬间的状态,因此在快照间隔期间它可能会有明显波动。

号主在certview.oracle.com网站上的证书清单截图。

关于号主,姚远:

  • Oracle ACE(Oracle和MySQL数据库方向)
  • 华为云最有价值专家
  • 《MySQL 8.0运维与优化》的作者
  • 拥有数十项数据库认证
  • 曾任IBM公司数据库部门经理
  • 20+年DBA经验,服务2万+客户
  • 精通C和Java,发明两项计算机专利
  • 两次获得国家部级奖
相关推荐
数据知道8 小时前
PostgreSQL 性能优化:连接数过多的原因分析与连接池方案
数据库·postgresql·性能优化
怣508 小时前
MySQL子查询实战指南:数据操作(增删改查)与通用表达式
数据库·chrome·mysql
刘一说8 小时前
Java 中实现多租户架构:数据隔离策略与实践指南
java·oracle·架构
范纹杉想快点毕业8 小时前
从单片机基础到程序框架:构建嵌入式系统的完整路径
数据库·mongodb
数据知道8 小时前
PostgreSQL性能优化:如何定期清理无用索引以释放磁盘空间(索引膨胀监控)
数据库·postgresql·性能优化
喵叔哟8 小时前
67.【.NET8 实战--孢子记账--从单体到微服务--转向微服务】--新增功能--分摊功能总体设计与业务流程
数据库·微服务·架构
tryCbest8 小时前
Oracle查看存储过程
数据库·oracle
咩咩不吃草8 小时前
【MySQL】表和列、增删改查语句及数据类型约束详解
数据库·mysql·语法
不懒不懒8 小时前
【MySQL 实战:从零搭建规范用户表(含完整 SQL 与避坑指南)】
数据库
ID_180079054738 小时前
Python结合淘宝关键词API进行商品价格监控与预警
服务器·数据库·python