Oracle10g中如何分析响应时间

来源:网络收集 时间:2025-08-16 下载这篇文档 手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:xuecool-com或QQ:370150219 处理(尽可能给您提供完整文档),感谢您的支持与谅解。点击这里给我发消息

Oracle10g中如何分析响应时间

在Oracle10g中,以前版本中比较难于获取的响应时间数据将会变得非常容易获取。

在以前看来,为了尽量获得数据库的最佳性能,Oracle的DBA们和性能分析专家一直很困难获得系统以及用户会话活动的一致的响应时间数据。DBA们面临的问题一直以来包括两个方面:第一个方面是准确定位数据库或者用户会话究竟在哪里消耗了时间;第二个方面就是确定用户体验的客观性质。

在数据库中产生所有可能的行为和交互作用,这些任务都不是没有价值的。 Oracle等待接口,在之前的很早的Oracle数据库版本中开始介绍的, 对于那些知道如何使用等待接口的管理员来说这已经成为一个伟大的开始,

即使它仍然缺乏告诉DBA系统或者用户会话是否有效的处理了事务或者查询这个理想的能力。 启用和钻研跟踪文件能够存储这个级别上的详细信息,但是对于大多数超负荷工作管理大型数据库的DBA们,

这个钻研是奢侈的而耗费时间的。

幸运的是,那些将数据库升级到Oracle10g的DBA们将会发现找到主要的响应时间变得很容易, 可以允许一个非常好的图表来显示系统和会话级的响应时间数据。

很重要的一点,Oracle的ADDM提供了一个查看响应时间的方法,通过自动分析收集的统计信息,识别问题区域,

甚至可以通过Oracle企业管理器网络控制的图形界面提供建议。

此外,与我们这里讨论相关的是Oracle10g数据库的历史数据机制允许DBA们按时查看对响应时间趋势的分析,

这将有助于DBA们确定事务/系统的高峰时期,更好的定位那些拉长批处理周期和ETL作业的进程和SQL语句。

这里主要讨论用于系统、会话和SQL级别上那些历史机制的用途。

系统层的响应时间分析:

先来看看典型的几个经常问到DBA们的问题:

通常来说,数据库运行的状况如何?

用户体验感觉的平均响应时间是多少?

什么行为是最影响整个响应时间的?

上述问题在Oracle10g数据库之前对于DBA们来说是相当不好回答的,

但是如果使用了最新的Oracle10g数据库之后,这些数据信息将会很容易的被捕获到。

首先,Oracle10g数据库运行的状况如何这个问题可以通过下面的查询来获得:

select METRIC_NAME,VALUE

from SYS.V_$SYSMETRIC

where METRIC_NAME IN ('Database CPU Time Ratio','Database Wait Time Ratio')

AND INTSIZE_CSEC = (select max(INTSIZE_CSEC) from SYS.V_$SYSMETRIC);

METRIC_NAME VALUE

------------------------------ ----------------------------------

Database Wait Time Ratio 31.3499111

Database CPU Time Ratio 68.6500888

Oracle10g数据库中的V$SYSMETRIC视图中存在一些非常有用的响应时间数据, 其中两个比较重要的就是Wait Time Ratio 和Database CPU Time Ratio. 上面的查询显示了数据库中最新的关于这两个统计数据的快照,

这将有助于帮助我们确定是否数据库正在经历着一个比较高的等待百分率和瓶颈。 数据库的CPU Time Ratio是由数据库中的\的数值除以CPU的数量,

\time\定义为数据库消耗在用户级别调用所花费的时间(不包括实例的后台进程活动所消耗的时间)。

比较高的值(90%-95%以上)代表很少的 等待和瓶颈活动,因为各个系统不同,这个阀值只能作为一个一般的规则来使用。

还可以使用如下的查询来迅速查看最新一个小时的信息,看看数据库的总性能如何:

select end_time,value

from sys.v_$sysmetric_history

where metric_name = 'Database CPU Time Ratio'

order by 1;

END_TIME VALUE

----------- --------------

2007-1-24 2 3.21949216

2007-1-24 2 3.01443414

2007-1-24 2 9.75636353

2007-1-24 2 9.28581409

2007-1-24 2 43.3490481

2007-1-24 2 38.8366361

2007-1-24 2 32.0272511

2007-1-24 2 0

2007-1-24 2 22.9580733

2007-1-24 2 33.0615102

2007-1-24 2 43.1294933

可以从V$SYSMETRIC_SUMMARY视图中获得数据库整体性能效率的最大、最小和平均值:

select CASE METRIC_NAME

WHEN 'SQL Service Response Time' then 'SQL Service Response Time (secs)'

WHEN 'Response Time Per Txn' then 'Response Time Per Txn (secs)'

ELSE METRIC_NAME

END METRIC_NAME,

CASE METRIC_NAME

WHEN 'SQL Service Response Time' then ROUND((MINVAL/100),2)

WHEN 'Response Time Per Txn' then ROUND((MINVAL/100),2)

ELSE MINVAL

END MININUM,

CASE METRIC_NAME

WHEN 'SQL Service Response Time' then ROUND((MAXVAL/100),2)

WHEN 'Response Time Per Txn' then ROUND((MAXVAL/100),2)

ELSE MAXVAL

END MAXIMUM,

CASE METRIC_NAME

WHEN 'SQL Service Response Time' then ROUND((AVERAGE/100),2)

WHEN 'Response Time Per Txn' then ROUND((AVERAGE/100),2)

ELSE AVERAGE

END AVERAGE

from SYS.V_$SYSMETRIC_SUMMARY

where METRIC_NAME in ('CPU Usage Per Sec',

'CPU Usage Per Txn',

'Database CPU Time Ratio',

'Database Wait Time Ratio',

'Executions Per Sec',

'Executions Per Txn',

'Response Time Per Txn',

'SQL Service Response Time',

'User Transaction Per Sec')

ORDER BY 1;

METRIC_NAME MININUM MAXIMUM AVERAGE

---------------------------------------------- ---------- ----------

CPU Usage Per Sec 0 53.9947577 11.1603280

CPU Usage Per Txn 0 168.731666 24.8848615

Database CPU Time Ratio 0 87.1866295 35.8114730

Database Wait Time Ratio 0 90.7141859 64.1885269

Executions Per Sec 0 540.768348 114.852472

Executions Per Txn 0 1911 279.912779

Response Time Per Txn (secs) 0 3.88 0.66

SQL Service Response Time (secs) 0 0 0

User Transaction Per Sec 0 4.70183486 0.94469007

上面的查询包含了更多的详细的响应时间数据。DBA们还需要收集在系统级别上的用户通讯的平均响应时间,

上面的查询给出了需要的结果。

如果用户抱怨响应时间太慢,那么DBA就应该查看Response Time Per Txn 和SQL Service Response Time数据是否存在数据库问题。

如果响应时间不在是那么渴求,那么DBA就会想了解究竟是什么类型的用户活动让数据库的响应变得如此的慢,

在Oracle10g数据库之前,这些信息 是比较难获取的,但是现在就变得非常容易,执行如下查询:

select case db_stat_name

when 'parse time elapsed' then

'soft parse time'

else db_stat_name

end db_stat_name,

case db_stat_name

百度搜索“70edu”或“70教育网”即可找到本站免费阅读全部范文。收藏本站方便下次阅读,70教育网,提供经典综合文库Oracle10g中如何分析响应时间在线全文阅读。

Oracle10g中如何分析响应时间.doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印 下载失败或者文档不完整,请联系客服人员解决!
本文链接:https://www.70edu.com/wenku/341807.html(转载请注明文章来源)
Copyright © 2020-2025 70教育网 版权所有
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:370150219 邮箱:370150219@qq.com
苏ICP备16052595号-17
Top
× 游客快捷下载通道(下载后可以自由复制和排版)
单篇付费下载
限时特价:7 元/份 原价:20元
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信:xuecool-com QQ:370150219