AIX 下oracle 数据库内存优化

内存访问的冲突出现在当进程申请的内存超过系统的物理内存总量时,为了处理这种情况,系统将程序与数据在内存和硬盘间进行交换。

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

调整 AIX 上的文件缓存
在AIX 上,可以通过vmtune 命令中的MINPERM 和MAXPERM 参数,调整系统文件缓存来控制内存交换操作,MINPERM 和MAXPERM 参数的调整应遵照以下的原则:
l 当内存中的文件缓存页在MINPERM 以下时,内存页交换算法同时交换文件缓存页和程序页(computational pages)
l 当内存中的文件缓存页在MAXPERM 以上时,内存页交换算法只交换文件缓存页。
l 当内存中的文件缓存页在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 的核心进程
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 的利用率提高。

小结
合理的内存配置,是Oracle 数据库性能调整的重要方面,其根本的目标是,首先尽量避免系统内存页的交换操作,然后尽量将应用程序经常用到的数据缓存在系统的SGA 区中。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/11134849/viewspace-659631/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/11134849/viewspace-659631/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值