li
  当前位置:主页 > 性能优化 > 文章内容
li
在AIX环境下Oracle 9i的性能调整
来源: www.ixdba.net  作者: IXDBA.NET官方    时间:2008-05-09   阅读:13  
本文章共1674字,分2页,当前第1页,快速翻页:
 

控制内存交换操作(Paging)

大量的内存交换操作会极大地影响系统的性能,尤其是在当数据库文件创建在文件系统上时(JFS and JFS2)。在这种情况下经常访问的数据,即在SGA中存在,也同样在文件的缓存中存在。这种相同的数据在内存中缓存两次的情况,会降低内存的使用效率,从而使内存频繁进行交换操作,造成系统的I/O瓶颈,降低整个系统的性能。

调整AIX上的文件缓存

在AIX上,可以通过vmtune命令中的MINPERM和MAXPERM参数,调整系统文件缓存来控制内存交换操作,MINPERM和MAXPERM参数的调整应遵照以下的原则:

当内存中的文件缓存页在MINPERM以下时,内存页交换算法同时交换文件缓存页和程序页(computational pages)

当内存中的文件缓存页在MAXPERM以上时,内存页交换算法只交换文件缓存页。

当内存中的文件缓存页在MINPERM和MAXPERM之间时,内存页交换算法通常只交换文件缓存页,但如果文件缓存页的交换率大于程序页时,程序页也同样被交换。

MINPERM和MAXPERM参数的缺省值

MINPERM = ((number of memory page) - 1024)*0.2

MAXPERM = ((number of memory page) - 1024)*0.8

可以用以下命令将MINPERM设为5%的内存页,而MAXPERM设为20%的内存页。

# vmtune -p 5 -P 20

缺省值分别为20%和80%。

在Oracle数据库应用的环境下,可以将MINPERM和MAXPERM分别设为5%和20%甚至更小,从而使内存更多地被用于Oracle的SGA而不是系统的文件缓存。

配置足够的交换区

如果交换区空间不足会造成系统响应速度变慢甚至挂起,交换区的大小取决于系统内存的大小以及应用程序对内存的需求。在AIX上可以动态增加交换区,也可以用lsps命令察看交换区的使用状况,以及用vmstat监视系统内存页交换的操作。

通常交换区的大小需要大于系统的实际内存,这主要取决于应用程序对内存的需求。用户需要监视交换区的使用状况,根据需要增加交换区的空间。对于运行Oracle Application或Oracle development tools可能需要较大的交换空间。

排定内存需求优先级

如果系统的内存不足,就需要对进程对内存使用的优先级进行排序,将内存优先分配给能获得更好的系统总体性能的进程。通常的顺序如下:

1. AIX和Oracle的核心进程

IXDBA.NET技术社区

2. 应用程序进程

3. Oracle的Redo log buffer

4. PGA和共享池(shared pool)

5. Oracle的数据缓存(block buffer cache)

例如:当你查询Oracle的动态性能表时发现共享池(shared pool)和数据缓存区(block buffer cache)都需要配置更多地内存,而你的系统中的空闲内存有限,那么将空闲内存分配给共享池比分配给数据缓存区有更好的效果。

数据块(Database block)的大小

用户可以选择Oracle数据库中数据块的大小以获得更好的性能,在AIX上通过设置DB_BLOCK_SIZE初始化参数,选择从2KB到32KB的数据块,缺省值是4KB。如果数据文件在文件系统上,则Oracle数据块的大小应为文件系统数据块4KB的整倍数。如果数据文件在系统裸设备上,则Oracle数据块的大小应为系统数据块512B的整倍数。

Oracle公司推荐,对于在线交易的应用(OLTP)或混合型的应用环境,采用2KB或4KB的数据块。对于BI的应用或决策支持系统(DSS),采用更大的数据块,如8KB,16KB或32KB。

调整日志归档缓存(Log Archive Buffers)

配置较大的缓存可以提高数据库日志归档的速度,但注意不要对整个系统的性能产生影响。用户可以将LOG_ARCHIVE_BUFFER_SIZE增加到128KB (其缺省值为4KB),会提高0-20%的数据库归档操作的性能。

调整SGA的大小

对于Oracle SGA来说,被系统的内存管理程序换出到交换区上,肯定是用户最不愿意见到的情况,这就需要系统配置有足够的内存。对于大量用户同时在线的应用,建议配置较大的SGA区。对于SGA影响最大的参数是DB_BLOCK_BUFFERS和SHARED_POOL_SIZE。增大这两个参数,取决于用户希望分配给SGA内存的大小,同时,增大这两个参数也会造成CPU的利用率提高。



阅读更多内容1 · 2 · 下一页>>


  上一篇: Oracle分区表及分区索引   下一篇: 系统表空间IO错误 数据损坏处理案...
li
 §相关评论  
 热点文章

·Resize datafile导致ASM Crash
·在Oracle10g RAC下新增ASM磁盘
·ORACLE SQL性能优化系列 (一)
·oracle性能调优:管理oracle日志
·oracle RAC环境中系统时钟的调
·why:Rac的心跳线不支持交叉线?
·RAC的VIP及实例依赖关系:版本O
·如何启动DataGuard的备用数据库
·系统表空间IO错误 数据损坏处理
·不幸中的万幸:遭遇ORA-00600 [
·用ORACLE的高级复制实现内外网
li
 编辑推荐
·Resize datafile导致ASM Crash
·在Oracle10g RAC下新增ASM磁盘
·ORACLE SQL性能优化系列 (一)
·oracle性能调优:管理oracle日志
·oracle RAC环境中系统时钟的调
·why:Rac的心跳线不支持交叉线?
·RAC的VIP及实例依赖关系:版本O
·如何启动DataGuard的备用数据库
·系统表空间IO错误 数据损坏处理
·不幸中的万幸:遭遇ORA-00600 [
·用ORACLE的高级复制实现内外网
li
 相关篇章
·Oracle分区表及分区索引
·oracle性能调优:管理oracle日志之...
·成为高效能DBA的七个必须习惯
·oracle性能调优:管理oracle日志之...
·oracle性能调优:管理oracle日志之...
·oracle性能调优:管理oracle日志之...
·阿里巴巴的DBA成长之路
·如何选择合适的Oracle优化器
·oracle 性能调优:调整SGA之Java池...
·oracle 性能调优:调整SGA之大池的...
·系统表空间IO错误 数据损坏处理案...
·ORA-01578: ORACLE data block c...
·如何查看和清除oracle无用的连接...
·ORA-16057: DGID from server no...
·PING[ARC0]: Heartbeat failed t...
·ORA-16025: parameter LOG_ARCHI...
·oracle dataguard常见故障解决方...
·oracle dataguard常见gap故障解决...
·如何设置oracle会话自动跟踪
·如何跟踪自己的会话或者是别人的...
 
li
设为首页 | 关于我们 | 技术服务 | 收藏本站 | 网站地图 | 联系方式 | 本站友情连接