《Oracle性能问题一般解决思路课件》由会员分享,可在线阅读,更多相关《Oracle性能问题一般解决思路课件(15页珍藏版)》请在金锄头文库上搜索。
1、Oracle 性能问题一般解决思路 高兴建主要方向v检查V$session_wait视图,查看当前等待事件,根据等待事件,判断是否由于锁等引起v通过操作系统命令top/topas检查耗CPU较高的进程,然后定位到对应的SQL语句。v通过SQL语句直接查占IO排名前多少位的SQL语句v查看V$sysstat看看是否hard parse非常多v检查alert.log是否包含了异常信息或者错误检查V$session_wait视图,查看当前等待事件vSelect event,count(*) from v$session_wait group by event;有问题的主要事件有:venqueue v
2、db file scattered read vdirect path read 或 direct path write vglobal cache cr requestvlibrary cache lock vlibrary cache pin vrow cache lock enqueue事件vENQUEUE事件说明当前会话在等待其他会话所占用的资源。该会话将一直等待下去直到它等待的会话释放资源,并可能将整个数据库hang住。多是DML类型锁。v查看enqueue的类型 SQ Enqueue for Sequence Numbers TX Enqueue for a Transaction
3、 select sid,chr(bitand(p1, -16777216)/16777215) |chr(bitand(p1,16711680)/65535) Name,(bitand(p1, 65535) Modefrom v$session_waitwhere event = enqueue;SID Name Mode- - -64 TX 6 enqueue事件解决方法: SELECT DECODE(REQUEST,0,Holder: ,Waiter: )|SID SESS,ID1,ID2, LMODE, REQUEST, TYPE FROM V$LOCK WHERE (ID1, ID2,
4、 TYPE) IN (SELECT ID1, ID2, TYPE FROM V$LOCK WHERE REQUEST0) ORDER BY ID1, REQUEST检查出标记为holder的会话号,并做进一步查看原因,可能需要将holder的会话杀掉。 如果enqueue类型是SQv$session_wait.p2 is DBA_OBJECTS.object_id, so you can find out which sequence the application is competing如果是TX型v$session.row_wait_obj# is DBA_OBJECTS.object_
5、iddb file scattered read该事件是指该会话在读很多数据块。一般情况下说明该会话在做全表扫描或者全索引扫描,当这种类型的事件较多时应该检查这些语句是否没有用到索引或者表上没有建合适的索引。direct path read 或 direct path write 该事件说明该会话在做外部排序。大量的外部排序会导致数据库性能很低,应该检查语句是否有问题。可以的话,可以增加PGA_AGGREGATE_TARGETglobal cache cr request 该事件说明RAC环境中,该会话在等待另外一个instance中的会话释放资源。如果较多的该事件发生时,必须检查另外的ins
6、tance等待的事件,看是否有异常语句在运行library cache lock主要是由于编译存储过程或者SQL硬解析等引起,多与Library cache pin 一起产生。 查看语句:必须以sys用户登录 SELECT decode(lock_a.kgllkreq,0,Holder:,Waiter:),sid,machine,program FROM X$KGLLK LOCK_A ,V$SESSION SES_A WHERE LOCK_A.KGLLKSES = SES_A.SADDR and lock_a.KGLLKHDL in( select KGLLKHDL from X$KGLLK
7、where KGLLKREQ 0) order by KGLLKHDL,kglLKreq library cache pin与Library cache lock相似,主要是由于ddl操作或者存储过程编译等引起。查看语句:必须以sys用户登录 SELECT decode(lock_a.kglpnreq,0,Holder:,Waiter:),sid,machine,program FROM X$KGLPN LOCK_A ,V$SESSION SES_A WHERE LOCK_A.KGLPNSES = SES_A.SADDR and lock_a.KGLPNHDL in( select KGLPN
8、HDL from X$KGLPN where KGLPNREQ 0) order by KGLPNHDL,kglpnreq通过操作系统命令top/topas检查耗CPU较高的进程,然后定位到对应的SQL语句。vHP-UNIXtop hvIBM AIXtopasv获得占CPU高的进程号后,到数据库里面执行下面的语句获得session信息Select * from v$session where paddr in(Select addr from v$process where spid =?)查占IO排名前多少位的SQL语句vselect * from (select sql_text,roun
9、d(a.disk_reads + a.buffer_gets)/a.executions),HASH_VALUE from v$sqlarea awhere executions 0order by 2 desc)where rownum 0v如果hard parse比例比较多,需要多检查是否v对已经存在业务,如果不能修改程序的话,可以尝试将参数cursor_sharing=similar查询长任务操作vV$session_longopsvselect sid,target,sofar,TOTALWORK,time_remaining,ELAPSED_SECONDS from v$session_longops用于记录登录用户的IP的触发器v将下面的触发器建到需要的用户下面即可vcreate or replace trigger tri_loggon_getip after logon on schemabegindbms_application_info.set_client_info(sys_context(USERENV,IP_ADDRESS);end;v查看方法select client_info from v$session where sid =? ,这时候出现的就是IP地址。