分享
 
 
 

优化策略

王朝other·作者佚名  2008-05-19
窄屏简体版  字體: |||超大  

性能调试的一般问题

1. Introduction 介绍

本文档包括了最一般的调优策略。关于各部分的更专门的信息可以通过提供的链接得到。

2. Shared Pool and Library Cache Performance Tuning 共享池和Library Cache的调优

Oracle将SQL语句、存储包、对象信息和很多其他的项目保存在SGA中一个叫共享池(shared pool)的地方。这个可共享的区域由一个成熟的高速缓存和堆管理器管理。它有3个基本的问题要克服:

1.) 内存分配的单元不是个常量。从池中分配的内存单元可能是从几个字节到几千个字节。

2.) 在用户完成工作时,不是所有的内存都能够释放出来,因为共享池的目标是使信息最大程度的共享。

3.) 没有一个象其他常规的高速缓存的文件做后备的存储那样磁盘空间供整页的导出。

只有可重新创建的信息可以从Cache中丢弃,在他被再次需要的时候再重新创建。

共享池调优的技巧有:

-刷( Flush)共享池可以使小块的内存合并为大块的内存。当共享池的碎片过多时,这能够暂时恢复性能。刷共享池可以使用语句:alter system flush shared_pool;

注意执行这个语句将会造成性能的暂时尖峰,因为对象都要重新加载。所以应当在数据库的负载不是很大的情况下进行。

- 确保联机事务处理( OLTP)应用使用绑定变量 (bind variables). 这一点对于决策支持系统(DSS)并不重要。

- 确保library cache 的命中率 95%

- 增大共享池并不总能解决命中率过多的问题。

3. Buffer Cache Performance Tuning 数据库缓存调优

数据库缓存保持了从磁盘上读去的数据块的备份。

因为缓存通常受到内存约束的限制,不是磁盘上所有的数据都可以放到缓存里。当缓存满了的时候,后来的缓存不中使得Oracle将已经在缓存中的数据写到磁盘上。后续的对写到磁盘上的数据的访问还会造成缓存不中。

数据库缓存调优的技巧如下:

避免以下的问题

- '缓存的最近最少使用(LRN)链'('cache buffers LRU chain' )的加锁竞争

- '平均写队列'("Average Write Queue" )长度过大

- 过多时间花在等待‘写完毕等待上’("write complete waits" )

- 过多时间花在等待‘缓冲释放等待’上 ("free buffer waits" )

4. Latch Contention 加锁(插销)竞争

插销加锁是SGA中保护共享数据结构的低层的串行化机制。插销latch是一类可以非常快的获得和释放的锁。插销锁的实现是依赖于操作系统的,尤其在关于一个进程是否会等待一个锁,和等多久方面。

有如下的锁(插销)需要调优:

- Redo Copy/Allocation Latch 重写日志的复制/分配插销

- Shared Pool Latch 共享池的插销

- Library Cache Latch Library Cache插销

5. Redo Log Buffer Performance Tuning 重写日志缓冲的调优

LGWR 将重写日志缓冲中的重写项写到重写日志文件中。

一旦LGWR将这些项复制到重写日志文件中,用户进程就可以重写这些项。统计项目"redo log space requests"反映了用户进程等待重写日志缓冲中空间的时间的数字。

设置重写日志大小的一些提示:

- "redo log space requests"的值应该接近0。

- 设定合适的重写日志的大小,建议每15-30分钟进行一次重写日志的切换。

6. Query Performance Tuning 查询效率的调优

如果查询运行得很慢,请考虑这些方面:

- 你希望这个查询运行的有多快以及有理由这样要求吗?

- 优化模式OPTIMIZER_MODE 设为何值?

- 查询涉及的索引都是有效的吗?

- 在数据库中有没有其他的长时间运行的查询(大查询)

对于CBO(基于成本的优化)In case of CBO:

- 表和索引上有统计信息吗?

- 统计信息是被计算出来的还是被估计出来的?

对于查询的性能调整由两个主要的调试工具:

- TKPROF

- AUTOTRACE

7. Rollback Segment Performance Tuning 回滚段的调优

Oracle数据库提供了任何数据库对象上的SELECT, INSERT, UPDATE, 和DELETE 操作的读一致性。回滚段用于保存由那些要回滚的动作或系统需要产生一个和前面某一时间读一致的影像所产生的可取消事务。

设置回滚段大小的技巧如下:

- 建议最少每4个事务一个回滚段

- 建议为长时间运行的大查询提供一个大回滚段。

- v$rollstat中的wrap数接近0。否则增大扩展大小(extent size)。

SELECT b.name, a.wraps FROM V$ROLLSTAT a, V$ROLLNAME b;

8. Temporary Tablespace Performance Tuning 临时表空间的调优

从RDBMS release 7.3开始,Oracle引入了临时表空间的概念。这个表空间用于保存临时对象,如排序段。排序段采用它所在的表空间的缺省存储参数(DEFAULT STORAGE (NEXT) 子句)作为自己的存储参数。

临时表空间的调优的技巧如下:

- 如果即使在稳定的状态下也存在很多的排序扩展锁(Sort Extent Pool latch)的竞争,你应该通过修改临时表空间的DEFAULT STORAGE 子句的NEXT值来增大扩展块的大小。

- 如果存在很多的排序扩展锁(Sort Extent Pool latch)的竞争并且这种等待是由于过多的并发的排序造成的,你应该增大SORT_AREA_SIZE参数的大小,以使更多的排序能保存在内存中。

- 建议让扩展块的大小和SORT_AREA_SIZE参数相同。

以此例说明为什么。 假设你的 extent size = 500K 而 sort_area_size = 1Mg.

现在如果有个到磁盘的排序,每次都要做2个500K的扩展,这会导致性能的降低。

9. Utlbstat/Utlestat Performance Tuning Utlbstat/Utlestat调优

Bstat/Estat 是一堆存放在你的$ORACLE_HOME/rdbms/admin目录下的SQL脚本,他们对于捕获系统范围的数据库性能统计的快照非常有用。UTLESTAT 创建这些视图的第二个快照,并将两个快照之间的差异报告到文件 'report.txt'中。

Bstat.sql 在你的sys用户下创建一系列的表和视图,其中包括开始时数据库性能统计的快照。

Estat.sql在你的sys用户下创建一系列的表,其中包括结束时数据库性能统计的快照和一个叫 'report.txt'的文件。

一些技巧:

- 确保你已经将TIMED_STATSTICS设为TRUE (这仅仅给数据库操作增加了一点非常小的开销)。

- 确保数据库在运行utlbstat前,已经启动并且运行了一段时间。

- 从svrmgrl 中而不是sql*plus中运行utbstat.sql和utlestat.sql。

- 确保在脚本utlbstat/estat运行时,数据库不被Down掉,否则产生的统计就不正确。

- 至少运行utlbstat/estat 1-3个小时,才好调试你的数据库。

10. Checkpoint Performance Tuning 检查点性能调优

检查点( Checkpoint)是一个数据库事件,用来同步内存和磁盘上的数据文件中的数据块。检查点的目的有两个:

(1) 建立数据的一致性

(2) 是数据库恢复更快。

调优检查点进程有如下的技巧:

- CKPT进程能够明显的提高效率来降低用户等待一个检查点操作完毕所需的时间。

- 如果LOG_CHECKPOINT_INTERVAL的值比重写日志( redo log)的大小大,那么 checkpoint只在ORACLE进行日志从一个组到另一组切换的时候才发生。这正是我们希望的。这个行为在 Oracle 8i中有了变化。

-当把LOG_CHECKPOINTS_TO_ALERT设为TRUE时,将把checkpoint启动和停止的时间记录在alert log日志里。这对于你确定checkpoint是否正以最佳的频率发生很有帮助。

- 理想的情况是,checkpoint在仅在日志切换时发生。

11. Import Performance Tuning 数据载入性能调优

没有什么固定的信息是关于如何加速那些慢得让人难以忍受的import的。显然import要花费它完成所需要的时间,但是作一些事情可以缩短他们所花的时间。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有