对Oracle性能调优的基本方案

以下的文章主要是对Oracle 性能优化基本方案的概述,Oracle 性能优化基本方案在实际中的应用比例还是占为多数的,如果你对这一技术,心存好奇的话,以下的文章将会揭开它的神秘面纱。

  1)设立合理的Oracle 性能优化目标。oracle培训

  2)测量并记录当前性能。

  3)确定当前Oracle性能瓶颈(Oracle等待什么、哪些SQL语句是该等待事件的成分)。

  4)把等待事件记入跟踪文件。

  5)确定当前的OS瓶颈。

  6)优化所需的成分(应用程序、数据库、I/O、争用、OS等)。

  7)跟踪并实施更改控制过程。

  8)测量并记录当前性能

  9)重复步骤3到7,直到满足优化目标

  1.设立合理的Oracle 性能优化目标

  重点:关于设立目标的最重要的一点是它们必须是可量化和可达到的。

  方法:目标必须是当前性能和所需性能的的陈述形式的语句。只需填写下列语句中的空格即可。

  花费了 (时/分/秒),但要求它在 (时/分/秒)内执行。

  使用了 (资源量),但它不能使用超过 。

  2. 测量并记录当前性能

  重点:

  (1)需要在峰值活动时间获得当前系统性能快照

  (2)关键是要在出现性能问题的时间段内采集信息

  (3)必须在合理的时间段上采集,一般在峰值期间照几个为期15分钟的快照

  方法:执行STATSPACK

  建立Oracle 性能快照表空间

  1.sqlplus sys as sysdba

  2.create tablespace perfstat datafile '/u02/oradata/dbnms/perfstat.dbf' size 500M extent management local;

  安装STATSPACK

  1.@$ORACLE_HOME/rdbms/admin/spcreate.sql;

  获取性能数据,可以生成多个快照

  1.sqlplus perfstat

  2.execute statspack.snap;

  生成性能快照的报表

  1.sqlplus perfstat

  2.select min(snap_id) snapid_min, max(snap_id) snapid_max from stats$snapshot;

  3.@$ORACLE_HOME/rdbms/admin/spreport;

  该报告中有关于性能的重要信息,如前5位的等待事件、cache大小、各种内存结构的命中率、每秒及每事务逻辑、物理读写数据块数、性能最差的sql语句等

  3. 确定当前Oracle性能瓶颈

  重点:从Oracle 等待接口v$system_event、v$session_event和v$session_wait中获得等待事件,进而找出影响性能的对象和sql语句

  方法:

  首先,利用v$system_event视图执行下面的查询查看数据库中某些常见的等待事件:

  1.select * from v$system_event

  2.where event in ('buffer busy waits',

  3.'db file sequential read',

  4.'db file scattered read',

  5.'enqueue',

  6.'free buffer waits',

  7.'latch free',

  8.'log file parallel write',

  9.'log file sync');

  接着,利用下面对v$session_event和v$session视图进行的查询,研究具有对上面显示的内容有贡献的等待事件的会话:

  1.select se.sid,s.username,se.event,se.total_waits,se.time_waited,se.average_wait

  2.from v$session s,v$session_event se

  3.where s.sid = se.sid

  4.and se.event not like 'SQL*Net%'

  5.and s.status = 'ACTIVE'

  6.and s.username is not null;

  使用下面查询找到与所连接的会话有关的当前等待事件。这些信息是动态的,为了查看一个会话的等待最多的事件是什么,需要多次执行此查询。

  1.select sw.sid,s.username,sw.event,sw.wait_time,sw.state,sw.seconds_in_wait SEC_IN_WAIT

  2.from v$session s,v$session_wait sw

  3.where s.sid = sw.sid

  4.and sw.event not like 'SQL*Net%'

  5.and s.username is not null

  6.order by sw.wait_time desc;


原文:http://space.itpub.net/29104442/viewspace-769129

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值