ORACLE性能优化

根据IO从高到低到SQL:
SELECT * FROM 
( SELECT PARSING_USER_ID,
        
        SORTS,
        COMMAND_TYPE,
        DISK_READS/(1+EXECUTIONS),first_load_time,
        sql_text,
  EXECUTIONS
        FROM v$sqlarea
        ORDER BY disk_reads/(1+EXECUTIONS) DESC 

WHERE ROWNUM<200 ;


//根据进程找当前运行的SQL
SELECT a.username,
        a.machine,
        a.program,
        a.sid,
        a.serial#,
        a.status,
        c.sql_text
    FROM v$session a,
        v$process b,
        v$sqlarea c
        WHERE b.spid in (10467)
        AND b.addr=a.paddr
        AND a.sql_address=c.address(+)

查看占io较大的正在运行的session
SELECT se.sid,
        se.serial#,
        pr.SPID,
        se.username,
        se.status,
        se.terminal,
        se.program,
        se.MODULE,
        se.sql_address,
        st.event,
        st.p1text,
        si.physical_reads,
        si.block_changes 
   FROM v$session se,v$session_wait st,
v$sess_io si, v$process pr
        WHERE st.sid=se.sid 
        AND st.sid=si.sid
        AND se.PADDR=pr.ADDR
        AND se.sid>6
        AND st.wait_time=0 
        AND st.event NOT LIKE '%SQL%'
        ORDER BY physical_reads DESC


对检索出的结果的几点说明:
  1、我是按每个正在等待的session已经发生的物理读排的序,因为它与实际的IO相关。

  2、你可以看一下这些等待的进程都在忙什么,语句是否合理? 
  Select sql_address from v$session where sid=;

  Select * from v$sqltext where address=;  字串7 
  执行以上两个语句便可以得到这个session的语句。你也以用alter system kill session 'sid,serial#';把这个session杀掉。

 

  3、应观注一下event这列,这是我们调优的关键一列,下面对常出现的event做以简要的说明: 
  a、buffer busy waits,free buffer waits这两个参数所标识是dbwr是否够用的问题,与IO很大相关的,当v$session_wait中的free buffer wait的条目很小或没有的时侯,说明你的系统的dbwr进程决对够用,不用调整;free buffer wait的条目很多,你的系统感觉起来一定很慢,这时说明你的dbwr已经不够用了,它产生的wio已经成为你的数据库性能的瓶颈,这时的解决办法如下: 
  a.1增加写进程,同时要调整db_block_lru_latches参数。 
  示例:修改或添加如下两个参数 
  db_writer_processes=4 
  db_block_lru_latches=8

 

  a、2开异步IO,IBM这方面简单得多,hp则麻烦一些,可以与Hp工程师联系。 
  b、db file sequential read,指的是顺序读,即全表扫描,这也是我们应该尽量减少的部分,解决方法就是使用索引、sql调优,同时可以增大db_file_multiblock_read_count这个参数。 

oracle 可以在 v$sqlarea (v$sqltext)查询到已经和正在运行的sql 
可以在v$open_cursor 中查到正open状态的cursor
可以通过 v$session   join  to  v$sql  查到正在running 的session和sql



你可能感兴趣的:(ORACLE性能优化)