TOMSYAN 发表于 2011-12-22 08:54

Oracle10gR2在RHEL 5下开启异步IO

<P>平台:Redhat Enterprise Linux 5 64bit,Oracle 10gR2 10.2.0.4 64bit</P>
<P>1、首先用root用户安装以下必要的rpm包</P>
<P># rpm -Uvh libaio-0.3.106-3.2.x86_64.rpm<BR># rpm -Uvh libaio-devel-0.3.106-3.2.x86_64.rpm</P>
<P>2、在系统级支持异步I/O</P>
<P><BR>  与介绍的在RHEL 3里面设置异步IO不同,不需要设置aio-max-size,而且’/proc/sys/fs’路径下也没有这个文件。因为从2.6 kernel开始,已经取消了对IO size的限制。另外根据,Oracle建议将aio-max-nr的值设置为1048576或更高。</P>
<P># echo &gt; /proc/sys/fs/aio-max-nr 1048576</P>
<P>要永久修改这个内核参数,需要在/etc/sysctl.conf加上下面这句<BR>fs.aio-max-nr = 1048576<BR>使参数生效<BR>#/sbin/sysctl -p</P>
<P>3、在数据库级启用异步I/O<BR>  首先修改数据库参数。与在RHEL 3里面设置异步IO不同,Oracle10gR2默认是打开了对异步IO的支持的,不需要重新编译数据库软件。在’$ORACLE_HOME/rdbms/lib’路径下,也没有’skgaioi.o’这个文件。在某些情况下,Oracle无法将IO行为或事件报告给操作系统,因此需要做以下操作。</P>
<P>这里开始换成oracle用户</P>
<P>SQL&gt; alter system set disk_asynch_io=TRUE scope=spfile;</P>
<P>SQL&gt; alter system set filesystemio_options=asynch scope=spfile;</P>
<P>SQL&gt;shutdown immediate<BR>$ cd $ORACLE_HOME/rdbms/lib<BR>$ ln -s /usr/lib/libaio.so.1 skgaio.o<BR>$ make PL_ORALIBS=-laio -f ins_rdbms.mk async_on<BR>SQL&gt;startup</P>
<P>  在Oracle10gR2中AIO默认已经是开启的了。可以通过ldd或者nm来检查oracle是否已经启用了AIO支持,有输出代表已经启用。</P>
<P>$ /usr/bin/ldd $ORACLE_HOME/bin/oracle | grep libaio<BR>libaio.so.1 =&gt; /usr/lib64/libaio.so.1 (0x00002aaaac4a9000)<BR>$ /usr/bin/nm $ORACLE_HOME/bin/oracle | grep io_getevent<BR>w io_getevents@@LIBAIO_0.4</P>
<P>4、检查异步I/O是否在使用<BR>  根据,可以通过查看slabinfo统计信息查看操作系统中AIO是否运行,slab是Linux的内存分配器,AIO相关的内存结构已经分配,kiocb值的第二列和第三列非0即是已使用。与kernel 2.4.x不同,没有显示kiobuf,因为从kernel 2.5.43开始,kiobuf已经从内核中被移除。</P>
<P>$ cat /proc/slabinfo | grep kio<BR>kioctx 64 110 384 10 1 : tunables 54 27 8 : slabdata 11 11 0<BR>kiocb 13 315 256 15 1 : tunables 120 60 8 : slabdata 21 21 44</P>
<DIV></DIV>
页: [1]
查看完整版本: Oracle10gR2在RHEL 5下开启异步IO