Chinaunix首页 | 论坛 | 博客
  • 博客访问: 121116
  • 博文数量: 45
  • 博客积分: 457
  • 博客等级: 下士
  • 技术积分: 612
  • 用 户 组: 普通用户
  • 注册时间: 2012-04-26 15:13
文章分类

全部博文(45)

文章存档

2013年(27)

2012年(18)

我的朋友

分类: Oracle

2013-08-23 15:12:00

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

  1)设立合理的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;

阅读(1041) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~