Oracle认证:OracleWaitInterface解释

来源:互联网 发布:显示qq密码软件 编辑:程序博客网 时间:2024/06/07 13:34

共享池和库缓存闩等待通常是由于量的硬解析,在使用文本常量的应用程序中这是很频繁的;可以通过使用绑定变量,设置CURSER_SHARING为FORCE解决;通过查看V$SQLAREA.PARSE_CALLS识别SQL语句。
  缓存缓冲链闩等待是由于低效的SQL语句引起的,当应用程序打开多个并行会话执行相同的语句查询相同的结果集时可以得到该冲突;另一个原因是热块在缓存缓冲中。可以查看V$SESSION_WAIT的P1RAW 列检查是否有热块在缓冲缓存中;可以通过EXP/IMP带热块的表,增加PCTFREE的值进行扩展;考虑减小具有许多热块的表的块(9i+)。
  缓存缓冲LRU链闩等待是由于有量的缓存缓冲活动。重复扫描量低选择性的索引或者执行全表扫描的语句通常是主要原因;只能通过调整SQL.
  行缓存对象闩保护数据字典,唯一方法是增加共享池的尺寸。
  。enqueue wait
  enqueue是应用于数据库资源的锁。它们由应用程序请求初始化,查询V$ENQUEUE_STAT查看各种信息。
  最常见的enqueue等待是TX,模式号为6.是一种行级锁,通过V$LOCK确定阻塞者。另一种模式号为4,通常是主键强制或等待数据块中的一个ITL槽;查看V$SEGMENT_STATISTICS决定ITL等待的值,统计名为‘ITL waits’。通过使用较高的INITTRANS和PCTFREE重建对象修复该问题。
  对于唯一键强制问题,会在多个用户同时向表插入相同的键时发生;方法是找出为什么应用程序允许用户同时尝试插入重复的键。
  另一种常见的enqueue是等待ST Enqueue,每个数据库只有一个ST锁,方法是更改UET$和FET$请求该锁。使用本地管理表空间修复,使用TEMPFILE重建所有临时表空间修复,如果不能从字典管理表空间更改,增加所有高速增长的段的next extent分区尺寸,同时允许预分配分区。
  另一种常见Enqueue是等待TM Enqueue,模式号为3.未索引外键是这种锁冲突的主要原因。如果应用程序显示使用LOCK TABLE语句也会发生这种锁,见V$SQLAREA.
  。Buffer busy waits
  通常是由于多个会话尝试读取块到内存中或者尝试将块钉在内存中时会发生。可以通过尝试降低级别或并行性,或增加对象的FREELISTS/FREELIST GROUPS;也可以尝试重建表使用较小的块或增加PCTFREE的值减少表中的行数。
  如果主要等待是段头,检查NEXT分区的小并确保PCTFREE和PCTUSED之间的gap不会太;如果主要等待是撤销段头,可能是由于有太多的小的回滚段,考虑使用系统管理撤销。
  诊断延迟相关的等待事件
  。Log file sync
  当会话等待LGWR写出缓冲时会发生这种情况,主要有三个原因:高提交率—应用程序相关,I/O子系统太慢—考虑RAW,RAID 0,光纤通道,过的日志缓冲。同时参数PROCESSES过可能也会造成该事件等待增加。
  。Log buffer space
  如果由于空间不足或LGWR进程不够快,会话等待拷贝重做条目到日志缓冲时会发生这种情况。如果是日志缓冲太小,则考虑增加它;如果是I/O子系统太慢—考虑使用NOLOGGING或升级硬件。
  。Free buffer
  当DBWR正在从SGA写出藏块时会发生该等待。
  主要原因有:编写得很差的SQL,DBWRs不够,较慢的I/O,延迟块清除,较小的缓冲缓存。
  延迟的块清除:第一个扫描刚被加载的表的进程将会进行该工作,全表扫描刚加载的表可以最小化该问题,或者分析这些数据也可以解决。
  缓冲缓存太小通常不是问题,在增加它之前考虑增加DBWR.
  。Write complete
  是前台进程等待DBWR写出块的征兆。检查db file parallel writes事件的情况。
  。Log file switch completion
  当重做日志太小并且事务产生量的重做日志条目时会发生这种事件。可以通过创建更的日志文件或可以通过创建更多的重组日志组完成。
  还有一些10g新增的等待事件和RAC环境下的等待事件。
  Dumps和Traces
  。主要是ORA-0600和核心ORA-7445事件;
  。作为一个DBA,必须熟悉ORADEBUG,可以通过oradebug dumplist和oradebug help得到帮助,该工具没有文档。
  。遇到块中断时需要dump数据文件和块:
  alter system dump datafile <file#> block <block#>;
  。控制文件也可以被dump,当跟踪恢复相关的问题和SCN同步问题时可能会有用。
  alter session set events ‘immediate trace name controlf level 10’;
  或:
  oradebug sitmypid
  oradebug ulimit
  oradebug dump controlf 10
  。共享池有问题时通常需要DUMP堆。
  alter sessions set events ‘immediate trace name heapdump level <level>’;
  或:
  oradebug sitmypid
  oradebug ulimit
  oradebug dump heapdump <level>
  。库缓存DUMP会给出库缓存中关于对象的详细信息。
  alter sessions set events ‘immediate trace name library_cache level 10’;
  或
  oradebug sitmypid
  oradebug ulimit
  oradebug dump library_cache 10
  。当诊断内存中断或死锁错误时可以使用DUMP进程状态。
  alter sessions set events ‘immediate trace name processstate level <level>’;
  oradebug sitmypid
  oradebug ulimit
  oradebug dump processstate<level>
  。当诊断数据库挂起条件时可以DUMP系统状态。
  alter sessions set events ‘immediate trace name systemstate level <level>’;
  或:
  oradebug sitmypid
  oradebug ulimit
  oradebug dump systemstate <level>

 

 

 

 

from:http://www.100ksw.com/jsj/oracle/xxjc/246558_3.shtml

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 wlan密码忘了怎么办 孩子多动怎么办呢 孩子性格太内向怎么办 孩子脾气暴躁易怒怎么办 小孩有点叛逆应怎么办 小孩太叛逆怎么办关住 对不听话的孩子怎么办 孩子在学校不听话怎么办 孩子叛逆不回家怎么办 孩子厌学怎么办青春期叛逆 孩子青春期叛逆家长怎么办 孩子老哭不听话怎么办 8岁宝宝不听话怎么办 儿孑不听话叛逆怎么办 孩子太小不听话怎么办 得了只有很紧张怎么办 内向的妈妈孩子怎么办 对孩子没有耐心怎么办 孩子心理有问题怎么办 孩子心里有问题怎么办 父母打架我该怎么办 爸爸妈妈要离婚怎么办 父母吵架怎么办动手了 父母因为钱吵架怎么办 父母吵架孩子该怎么办 特别倔强的孩子怎么办 孩子胆小不自信怎么办 孩子不自信家长怎么办 二年级孩子厌学怎么办 儿童注意力不集中怎么办 小学数学成绩差怎么办 孩子英语成绩差怎么办 小学成绩差初中怎么办 小孩一年级成绩不好怎么办 孩子的记忆力差怎么办 普法考试没有考怎么办 小孩迷上玩手机怎么办 营养师证取消了怎么办 变频器输出缺相怎么办 体育中考来月经怎么办 不动精子率低怎么办