网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.Oracle常見問題集(四).
.认识系统服务 daemons.
.铁道部运营财务收入系统Oracle数.
.Oracle 9i 数据库里指针共享的增.
.在Oracle中找出重复的纪录的方法.
.角斗士般的Oracle性能.
.得到电影而不是图片:闪回版本查.
.讲解racle缓冲块(data block)状.
.Oracle数据库的管理.
.定时执行存储过程对库表及索引进.
.在Unix下的Oracle 8.1.7.4内安装.
.当“菜鸟”遭遇 Linux.
.EXP-00008: ORACLE error 904 en.
.PL/SQL基本语法要素.
.教你轻松解决Oracle数据库的服务.
.在oracle一个有60万记录的表中删.
.学习Linux的七点忠告.
.数据库运行在非归档模式下,数据.
.[Oracle]Redo log日志组故障分析.
.如何保持Oracle数据库优良性能.

Oracle 9i在AIX上的性能调整--内存篇

发表日期:2008-2-9



  内存访问的冲突出现在当进程申请的内存超过系统的物理内存总量时,为了处理这种情况,系统将程序与数据在内存和硬盘间进行交换。   控制内存交换操作(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的核心进程
  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区中。
上一篇:Oracle数据库磁盘输入输出性能和优化 人气:1005
下一篇:AIX系统下的小型计算机系统接口性能优化 人气:1033
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐