oracle时间模型
Oracle在9i或者早期的版本,对于性能优化方面,主要采用命中率模型,后面的版本,也保留着命中率模型,
比如在awr报告中,Instance Efficiency Percentages (Target 100%)就有关于buffer cache,library cache等相关的命中率。
命中率在性能优化时主要体现在:
- 当命中率不高时,可以通过参数的调整,提高命中率,从而可以提高系统的处理能力
 
不过命中率的弊端也显而易见:
- 命中率无法看到系统的cpu和IO处理能力的分配。
 - 当系统存在性能问题时,比如:应用并发设计问题,锁争用等问题时,命中率无法有效的反映到。
 
所以,oracle引入了时间模型的概念:
这里有几个概念:
- 响应时间=服务时间+等待时间
 - 从数据库的角度等价于:数据库响应时间=cpu时间+等待时间。
 
- elapse time:指时空上的物理时间
 - db time:db time反映系统整体的资源(cpu,IO)被oracle使用的百分比情况,以user call为视角
 - cpu time:指cpu的使用的有效时间
 
Db time= DB CPU+Foreground NO-Idle wait time + DB CPU ON QUEUE
这里边:
- db cpu即数据库任务使用cpu的时间
 - Foreground NO-Idle wait time:非空闲的等待(不包括backgroud进程)
 - DB CPU ON QUEUE:这里代表的是ready to run,但没有获得cpu运行时间片的在队列中等待时间
 
下面对数据库进行cpu密集型的测试:
$ cat testcpu.sh
#!/bin/sh
. /home/oracle/.bash_profile
sqlplus -S /nolog<<EOF
conn /as sysdba
declare
cnt number;
p number;
begin
cnt:=dbms_random.value(1,1000000);
p:=dbms_random.value(1,1000000);
while(1>0) loop
cnt:=mod(cnt*p,1000000);
end loop;
end;
/
EOF
###################################################
cat thread.sh
#!/bin/sh
for((i=1;i<=16;i++))
do
/home/oracle/testcpu.sh &
done
分别16,32个线程进行压力测试:
thread cpu loadavg(1min) db time cpu time elapse time
16 100% 16.08 31,138s 31,069s 34.45 (mins)
32 100% 31.81 54,812s 28,014s 30.16 (mins)
这里cpu被完全利用,cpu time大小为30*60*16=28,800s;(上面实验中取的awr时间在30分钟左右)
而db time会随着线程数的增加有所增加,虽然可能没有获得cpu时间,但是在run queue队列上,也会计入db time。
下面看下具体的awr报告:
16个并发进程下:
<pre class="brush: sql; title: ; notranslate" title="">
Snap Id Snap Time Sessions Curs/Sess
--------- ------------------- -------- ---------
Begin Snap: 14551 18-Apr-12 23:00:25 36 2.1
End Snap: 14552 18-Apr-12 23:34:51 20 2.1
Elapsed: 34.45 (mins)
DB Time: 518.97 (mins) Time Model Statistics DB/Inst: xxx Snaps: 14551-14552
-> Total time in database user-calls (DB Time): 31138.3s
-> Statistics including the word "background" measure background process
time, and so do not contribute to the DB time statistic
-> Ordered by % or DB time desc, Statistic name Statistic Name Time (s) % of DB Time
------------------------------------------ ------------------ ------------
sql execute elapsed time 31,137.4 100.0
DB CPU 31,068.7 99.8
PL/SQL execution elapsed time 31,065.0 99.8
parse time elapsed 3.4 .0
hard parse elapsed time 3.3 .0
hard parse (sharing criteria) elapsed time 0.2 .0
hard parse (bind mismatch) elapsed time 0.1 .0
DB time 31,138.3 N/A
-------------------------------------------------------------
32个并发进程下:
Snap Id Snap Time Sessions Curs/Sess
--------- ------------------- -------- ---------
Begin Snap: 14552 18-Apr-12 23:34:51 20 2.1
End Snap: 14554 19-Apr-12 00:05:01 52 2.5
Elapsed: 30.16 (mins)
DB Time: 913.54 (mins)
Time Model Statistics DB/Inst: xxx Snaps: 14552-14554
-> Total time in database user-calls (DB Time): 54812.4s
-> Statistics including the word "background" measure background process
time, and so do not contribute to the DB time statistic
-> Ordered by % or DB time desc, Statistic name Statistic Name Time (s) % of DB Time
------------------------------------------ ------------------ ------------
sql execute elapsed time 54,811.1 100.0
PL/SQL execution elapsed time 54,776.6 99.9
DB CPU 28,013.8 51.1
parse time elapsed 2.8 .0
hard parse elapsed time 2.6 .0
hard parse (sharing criteria) elapsed time 2.5 .0
hard parse (bind mismatch) elapsed time 0.2 .0
DB time 54,812.4 N/A
了解了awr里的时间模型:那么接下来:
1,等待事件
  oracle记录埋点的事件所花费的时间,不同的版本等待事件略有差异。
  查询v$system_event来监控到oracle各种等待时间的时间,就可以诊断数据库的性能瓶颈了。
2,top sql:
  oracle在sql的执行监控中记录了八个时间:
  APPLICATION_WAIT_TIME,CONCURRENCY_WAIT_TIME,CLUSTER_WAIT_TIME,USER_IO_WAIT_TIME,PLSQL_EXEC_TIME,JAVA_EXEC_TIME,CPU_TIME,ELAPSED_TIME。
  oracle可以根据这些时间来监控sql的执行情况。
oracle时间模型的更多相关文章
- Oracle Time Model Statistics(时间模型统计)
		
Oracle数据库从10g開始,启用以时间模型统计为主.命中率为辅等性能度量指标.基于时间模型统计,主要是基于操作类型測量在数据库中花费的时间的统计信息.最重要的时间模型统计是数据库时间.或DB时间. ...
 - 【Oracle】转:通过案例学调优之--Oracle Time Model(时间模型)
		
转自:http://blog.51cto.com/tiany/1596012 通过案例学调优之--Oracle Time Model(时间模型) 数据库时间 优化不仅仅是缩短等待时间.优化旨在缩短最终 ...
 - 【Oracle】Oracle时间日期格式
		
to_date("要转换的字符串","转换的格式") 两个参数的格式必须匹配,否则会报错. 即按照第二个参数的格式解释第一个参数. to_char(日期,& ...
 - ORACLE时间函数(SYSDATE)深入理解
		
ORACLE时间函数(SYSDATE)深入理解 加法 select sysdate,add_months(sysdate,12) from dual; --加1年 select sysdate,add ...
 - oracle 时间函数
		
加法 select sysdate,add_months(sysdate,12) from dual; --加1年 select sysdate,add_months(sysdate,1) from ...
 - ORACLE时间日期格式使用总结(参考网上资料汇总)
		
Oracle时间日期操作 sysdate+(5/24/60/60) 在系统时间基础上延迟5秒 sysdate+5/24/60 在系统时间基础上延迟5分钟 sysdate+5/24 在系统时间基础上延迟 ...
 - Oracle时间日期函数
		
ORACLE日期时间函数大全 TO_DATE格式(以时间:2007-11-02 13:45:25为例) Year: yy two digits 两位年 ...
 - Oracle时间换算:日,月,周数,星期,年
		
http://blog.csdn.net/liangweiwei130/article/details/37930383 Oracle时间换算,留做记号!
 - ORACLE时间函数(SYSDATE)简析
		
ORACLE时间函数(SYSDATE)简析 分类: 原文地址:ORACLE时间函数(SYSDATE)简析 作者:skylway 加法 select sysdate,add_months(sysdate ...
 
随机推荐
- 关于Handler与异步消息处理循环的摘抄
			
Message:消息,其中包含了消息ID,消息处理对象以及处理的数据等,由MessageQueue 统一队列,终由Handler处理. Handler:处理者,负责Message的发送及处理.使用Ha ...
 - pop动画大全 只能时代程序员更应该关心效果而不是冷冰冰的代码
			
下载地址 https://pan.baidu.com/s/1o8pQWau
 - OC - 6.block与protocol
			
一.block 1> 基本使用 相当于用来存放代码的代码块 效率高 若没有形参可以省略小括号 2> block与函数的相同点 可以保存代码 可以有返回值 可以有形参 调用方式一样 3> ...
 - PHP学习笔记(六)
			
<Wordpress 50个过滤钩子> 1-10 过滤钩子是一类函数,wordpress执行传递和处理数据的过程中,在针对这些数据做出某些动作之前的特定点执行.本质上,就是在wordpre ...
 - 九度OJ 1042 Coincidence -- 动态规划(最长公共子序列)
			
题目地址:http://ac.jobdu.com/problem.php?pid=1042 题目描述: Find a longest common subsequence of two strings ...
 - 九度OJ 1370 数组中出现次数超过一半的数字
			
题目地址:http://ac.jobdu.com/problem.php?pid=1370 题目描述: 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如输入一个长度为9的数组{1,2 ...
 - struts导包
			
我用的是struts-2.2.3,开始把全部的jar包都放进去了,可是一直报 信息: Parsing configuration file [struts-plugin.xml]2011-6-11 8 ...
 - 青瓷qici - H5小游戏 抽奖机 2 界面布局
			
背景图片 首先我们需要在当前场景下面创建UI的根节点,这个根节点决定了我们整个游戏的元素布局,以及适应多分辨率的缩放布局问题,所以我们其他的元素都要放在UIRoot下面. 考虑到我自己测试的时候在PC ...
 - 青瓷qici - H5小游戏 抽奖机 4 运行脚本编写
			
hello,小伙伴们,我们来继续编写相关的程序. 前几章我们已经基本把界面等问题搞定了,现在我们就来写脚本让整个流程统一起来. 看看我们现在有了什么?一个界面还有他的层次结构 青瓷界面绑定UI.js创 ...
 - 使用reinterpret_cast的危险
			
关键字: c++ cast // Cast.cpp : Defines the entry point for the console application. // #include "s ...