`
refurbish
  • 浏览: 27850 次
  • 性别: Icon_minigender_1
  • 来自: 福州
文章分类
社区版块
存档分类
最新评论

Oracle DBA优化数据库性能心得体会【转】

 
阅读更多



作者:佚名    阅读人次:2822    文章来源:天极论坛整理    发布时间:2007-9-24    网友评论(1)条


很多的时侯,做Oracle[/U] DBA的我们,当应用管理员向我们通告现在应用很慢、数据库很慢的时侯,我们到数据库时做几个示例的Select也发现同样的问题时,有些时侯我们会无从下手,因为我们认为数据库的各种命种率都是满足Oracle文档的建议。实际上如今的优化己经向优化等待(waits)转型了,实际中性能优化最根本的出现点也都集中在IO,这是影响性能最主要的方面,由系统中的等待去发现Oracle库中的不足、操作系统某些资源利用的不合理是一个比较好的办法,下面把我的一点实践经验与大家分享一下,本文测重于Unix环境。
一、通过操作系统的一些工具检查系统的状态,比如CPU、内存、交换、磁盘的利用率,根据经验或与系统正常时的状态相比对,有时系统表面上看起来看空闲这也可能不是一个正常的状态,因为cpu可能正等待IO的完成。除此之外我们还应观注那些占用系统资源(cpu、内存)的进程。
1、如何检查操作系统是否存在IO的问题?使用的工具有sar,这是一个比较通用的工具。
Rp1#sar -u 2 10
即每隔2秒检察一次,共执行20次,当然这些都由你决定了。
示例返回:
HP-UX hpn2 B.11.00 U 9000/800 08/05/03
18:26:32 %usr %sys %wio %idle
注:我在redhat下查看是这种结果,不知%system就是所谓的%wio。
Linux 2.4.21-20.ELsmp (YY075) 05/19/2005
10:36:07 AM CPU %user %nice %system %idle
10:36:09 AM all 0.00 0.00 0.13 99.87
10:36:11 AM all 0.00 0.00 0.00 100.00
10:36:13 AM all 0.25 0.00 0.25 99.49
10:36:15 AM all 0.13 0.00 0.13 99.75
10:36:17 AM all 0.00 0.00 0.00 100.00
10:36:17 AM CPU %user %nice %system %idle
10:36:19 AM all 0.00 0.00 0.00 100.00
10:36:21 AM all 0.00 0.00 0.00 100.00
10:36:23 AM all 0.00 0.00 0.00 100.00
10:36:25 AM all 0.00 0.00 0.00 100.00
其中的%usr指的是用户进程使用的cpu资源的百分比,%sys指的是系统资源使用cpu资源的百分比,%wio指的是等待io完成的百分比,这是值得我们观注的一项,%idle即空闲的百分比。如果wio列的值很大,如在35%以上,说明你的系统的IO存在瓶颈,你的CPU花费了很大的时间去等待IO的完成。Idle很小说明系统CPU很忙。像我的这个示例,可以看到wio平均值为11说明io没什么特别的问题,而我的idle值为零,说明我的cpu已经满负荷运行了。
当你的系统存在IO的问题,可以从以下几个方面解决:
*联系相应的操作系统的技术支持对这方面进行优化,比如hp-ux在划定卷组时的条带化等方面。
*查找Oracle中不合理的sql语句,对其进行优。
*对Oracle中访问量频繁的表除合理建索引外,再就是把这些表分表空间存放以免访问上产生热点,再有就是对表合理分区。
常用的工具便是vmstat,对于hp-unix来说可以用glance,Aix来说可以用topas,当你发现vmstat中pi列非零,memory中的free列的值很小,glance,topas中内存的利用率多于80%时,这时说明你的内存方面应该调节一下了,方法大体有以下几项。
*划给Oracle使用的内存不要超过系统内存的1/2,一般保在系统内存的40%为益。
*为系统增加内存。
*如果你的连接特别多,可以使用MTS的方式。
*打全补丁,防止内存漏洞。
3、如何找到点用系用资源特别大的Oracle的session及其执行的语句。
Hp-unix可以用glance,top,IBM AIX可以用topas,此外可以使用ps的命令。通过这些程序我们可以找到点用系统资源特别大的这些进程的进程号,我们就可以通过以下的sql语句发现这个pid正在执行哪个sql,这个sql最好在pl/sql developer,toad等软件中执行, 把<>中的spid换成你的spid就可以了。
SELECT a.username,a.machine,a.program,a.sid,a.serial#,
a.status,c.piece,c.sql_text from v$session a,v$process b,
v$sqltext c WHERE b.spid='ORCL' AND b.addr=a.paddr AND
a.sql_address=c.address(+)order BY c.piece
我们就可以把得到的这个sql分析一下,看一下它的执行计划是否走索引,对其优化避免全表扫描,以减少IO等待,从而加快语句的执行速度。
提示:我在做优化sql时,经常碰到使用in的语句,这时我们一定要用exists把它给换掉,因为Oracle在处理In时是按Or的方式做的,即使使用了索引也会很慢。
比如:
SELECT col1,col2,col3 FROM table1 a
WHERE a.col1 not in (SELECT col1 FROM table2)
可以换成:
SELECT col1,col2,col3 FROM table1 a
WHERE not exists
(SELECT 'x' FROM table2 b
WHERE a.col1=b.col1)
4、另一个有用的脚本:查找前十条性能差的sql。
SELECT * FROM (select PARSING_USER_ID,EXECUTIONS,SORTS,
COMMAND_TYPE,DISK_READS,sql_text FROM v$sqlarea
order BY disk_reads DESC )where ROWNUM<10 ;
二、迅速发现Oracle Server的性能问题的成因,我们可以求助于v$session_wait这个视图,看系统的这些session在等什么,使用了多少的IO。以下是我提供的参考脚本:
脚本说明:查看占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=;
执行以上两个语句便可以得到这个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这个参数。
c、db file scattered read,这个参数指的是通过索引来读取,同样可以通过增加db_file_multiblock_read_count这个参数来提高性能。
d、latch free,与栓相关的了,需要专门调节。
e、其他参数可以不特别观注。
其他的优化手段似乎主要集中在SQL查询语句上面,Oracle本身也提供了优化器。看来DBA的学问不少啊。
分享到:
评论

相关推荐

    Oracle DBA优化数据库性能心得体会

    ### Oracle DBA优化数据库性能心得体会 在日常工作中,Oracle数据库管理员(DBA)经常会遇到应用程序管理员反馈说应用响应缓慢的情况,而这种情况下通过简单的查询操作也能感受到明显的延迟。尽管数据库的各项指标...

    OracleDBA优化数据库性能心得体会

    Oracle DBA在优化数据库性能时,常常面临应用速度慢、数据库响应时间长的问题。尽管我们可能会检查各种指标,确保它们符合Oracle官方的建议,但现代的优化策略更侧重于识别和处理等待事件(waits)。在实践中,IO...

    DBA优化数据库性能心得

    作为一名专业的Oracle DBA,优化数据库性能是日常工作中至关重要的任务。在面对应用性能下降的问题时,我们往往会发现数据库响应变慢。此时,我们不能再仅仅依赖于传统的指标,而是需要转向优化等待事件,即关注...

    Oracle10g数据库心得

    Oracle 10g在性能、可用性、可管理性和安全性等方面都有显著提升,为数据库管理员(DBA)提供了强大的工具和功能。以下是对Oracle 10g数据库的一些核心知识点的详细说明: 1. **数据存储与表空间**:Oracle 10g中,...

    oracle dba 日记

    书中的日记形式展现了DBA在日常工作中遇到的问题及其解决方案,同时也分享了作者的心得体会。这本书对于想要深入理解Oracle数据库管理和运维的读者来说,具有很高的参考价值。 在DBA的成长之路上,性格扮演着重要的...

    ORACLE数据库学习心得.pdf

    Oracle数据库学习心得 Oracle数据库是当前最流行的关系数据库管理系统之一,它具有强大的功能和高性能。本文将从 Oracle 数据库的特点、总体结构、逻辑结构三个方面对 Oracle 数据库进行详细的介绍。 一、Oracle ...

    Oracle DBA突击帮你赢得一份DBA职位(完全高清版)1

    第1章至第4章是基础篇,包括数据库建模、Oracle体系结构、网络结构、备份恢复和使用OEM,这些对于刚刚从事DBA或者试图转做DBA的朋友都是必备知识。第5章至第9章是中级篇,专门讨论性能调整,包括性能优化原理、...

    Oracle使用疑难问题汇总

    教程名称:Oracle使用疑难问题汇总课程目录:【】Oracle DBA优化数据库性能心得体会【】ORACLE 中ROWNUM用法总结【】Oracle 查询表空间使用情况(经典篇)【】Oracle下巧用bulk collect实现cursor批量fetch【】...

    oracle DBA手记1-2册

    Oracle DBA,全称Oracle Database Administrator,是Oracle数据库系统的管理员,负责数据库的规划、安装、配置、维护和优化。Oracle数据库是全球广泛使用的商业关系型数据库管理系统,尤其在企业级应用中占据主导...

    精通 oracle 11g数据库管理(expert oracle database 11g administration)

    - **参与社区讨论**:加入 Oracle 技术社区,与其他 DBA 交流心得,有助于解决难题并拓宽视野。 《精通 Oracle 11g 数据库管理》这本书不仅适合初学者入门,也适合有一定经验的 DBA 进一步提升技能。通过系统学习...

    让Oracle跑得更快—Oracle10g性能分析与优化思路

    让Oracle跑得更快—Oracle 10g性能分析与优化思路内容简介:在这本书里读者将会学到作者在性能优化方面的一些思路和思考,一些故障处理的方法和原则,这些东西是作者在实践中长期积累的心得体会,当读者掌握了一些...

    Oracle入门心得文档

    从理解其体系结构,到掌握数据库和逻辑结构的概念,再到实践操作,每一个环节都为成为一名合格的Oracle DBA打下坚实的基础。希望这份入门心得能帮助你在Oracle的世界中找到方向,不断进步。在实践中遇到问题时,不要...

    Oracle 数据库优化实战心得总结

    优化sql语句 1)减少对数据库的查询次数,即减少对系统资源的请求,使用快照和显形图等分布式数据库对象可以减少对数据库的查询次数。 2)尽量使用相同的或非常类似的SQL语句进行查询,这样不仅充分利用SQL共享池中...

    Oracle数据库命令 个人总结

    Oracle数据库命令个人总结是徐博文在2014年3月整理的关于Oracle数据库的命令和心得的总结。下面是从该总结中提取的重要知识点: 1. 查询数据库数据文件的基本字段信息:使用DESC DBA_DATA_FILES命令可以查询数据库...

    X-01-Oracle-Oracle SQL高级编程(学习心得)

    本书深入探讨了Oracle SQL的高级特性和优化策略,旨在帮助读者掌握Oracle数据库的独特优势,提升SQL查询性能,以及在不修改代码的情况下优化查询。 首先,书中详尽地介绍了SQL的核心概念,包括SQL语言的基础,如DML...

    Oracle性能调优实践中的几点心得

    本文主要分享了Oracle DBA在实际工作中遇到性能问题时的一些解决策略,重点在于通过监控操作系统层面的指标来诊断Oracle数据库的性能瓶颈。 首先,针对IO问题,DBA可以通过系统工具如`sar`来检查CPU的用户使用率 `%...

    【dba必看】老白DBA日记

    他不仅分享了优化参数配置、SQL语句的方法,还提供了如何通过分析执行计划来定位和解决问题的案例,这对于任何想要提升Oracle数据库性能的DBA来说,都是弥足珍贵的经验。 数据库的安全性同样也是老白关注的重点之一...

    Oracle+DBA成功之路(Secooler)

    - **优化与规划**:定期分析表空间扩展、数据增长趋势,进行健康检查,优化数据库性能,制定空间管理规划。 - **故障排除与应急响应**:面对突发状况,能够迅速定位问题根源,实施有效的解决方案,确保业务连续性。 ...

    oracle学习心得体会.docx

    Oracle数据库是世界上最流行的数据库管理系统之一,尤其在企业级应用中占据重要地位。本文将深入探讨Oracle数据库的基础知识,包括其与SQL Server的对比、数据库管理、表空间、用户权限以及SQL命令的使用。 首先,...

Global site tag (gtag.js) - Google Analytics