Oracle在Solaris操作系统上实现异步I/O

简介:

一、 VXFS文件系统的简介

  VXFS文件系统是Veritas公司推出的一种高性能,高可用性的文件系统,一般用于数据中心。它是一种基于扩展的文件系统,能够让应用程序读取和写入大的连续块,适用于OLTP系统和DSS系统。

  Oracle数据库在Solaris操作系统上的vxfs文件系统上是可以实现异步I/O的,那Oracle数据库在vxfs文件系统中究竟该不该使用异步I/O?如何去判断是否Oracle数据库是真正实现了异步I/O?下面就这几个问题来具体的看看Oracle数据库在vxfs文件系统上的异步I/O。

  二、 VXFS文件系统上如何启用异步I/O

  首先我们必须要知道Solaris操作系统上那些磁盘上的文件系统是vxfs格式的,如何来查看一下哪些磁盘是属于vxfs格式的呢,可以使用如下的命令来查看:

Df -F vxfs

  /opt/oracle/db02 (/dev/vx/dsk/ipasdg/db02_vol):55665072 blocks 869766 files

  /opt/oracle/db03 (/dev/vx/dsk/ipasdg/db03_vol):41688928 blocks 651380 files

  /opt/oracle/db04 (/dev/vx/dsk/ipasdg/db04_vol):41688928 blocks 651380 files

  /opt/oracle/arch (/dev/vx/dsk/ipasdg/arch_vol):164632064 blocks 2572348 files

  /backup (/dev/vx/dsk/ipasdg/backup_vol):314529872 blocks 4914519 files


如果想在vxfs上面使用异步I/O,首先必须要安装一个叫做Quick I/O的模块,并且要启用Quick I/O,这个模块是需要单独向Veritas公司购买license的。默认的时候vxfs文件系统mount的时候是启用了Quick I/O的,如果在mount的时候指定了-o noqio的选项,那么Quick IO是被禁用的。

  如果想查看在一个文件系统上是否采用了Quick IO,常用的fsadmin,fstype这些命令都无法看出来,/etc/mnttab、/etc/vfstab这些文件也没有记录相关的信息。这里 介绍一种方法可以查看文件是否是Quick I/O的文件:

  ls -al 列出所有文件,包括Quick I/O文件和它的链接.

  $ ls -al d* .d*

  -rw-r--r-- 1 dba 104890368 Oct 2 13:42 .dbfile

  lrwxrwxrwx 1 dba 17 Oct 2 13:42 dbfile -> \ .dbfile::cdev:vxfs:

  ls -lL 显示是否Quick I/O被成功安装和启用。

  $ ls -lL dbfile

  crw-r--r-- 1 dba 45, 1 Oct 2 13:42 dbfile

  第一个字符c,表明这是一个裸字符设备文件,如果没有这个字符则表明Quick I/O没有正确安装或者是没有一个合法的license key。

  确认文件系统启用了Quick I/O后,然后就可以给Oracle配置异步I/O了,在Oracle的初始化参数中配置DISK_ASYNCH_IO = TRUE,然后重启数据库让其生效。

  因为启用了Quick I/O后,在OS级别上是消除了缓冲的,所以数据库的buffer cache在启用了Quick I/O后是应该需要增加的。

  三、 如何检测在VXFS文件系统上是否支持异步I/O

  对于Solaris操作系统可以使用下面的一段代码来检测系统是否支持异步I/O:

  原代码如下:

 /*

  * Quick kaio test. Read 1k bytes from a file using async I/O.

  * To compile:

  * cc -o aio aio.c -laio

  * To run:

  * aio file_name

  */

  #include

  #include

  #include

  #include

  #define BSIZE 1024

  main(int argc, char *argv[])

  {

  aio_result_t res;

  char buf[BSIZE];

  int fd;

  if ((fd=open(argv[1], O_RDONLY)) == -1) {

  perror("open");

  exit(-1);

  }

  aioread(fd, buf, BSIZE, 0L, SEEK_SET, &res);

  aiowait(0);

  if (res.aio_return == BSIZE) {

  printf("aio succeeded\n");

  close(fd);

  exit(0);

  }

  perror("aio");

  }


然后使用root用户编译:

  # cc -o aio aio.c -laio
这样就可以用来检测系统是否支持异步I/O了。










本文转自 wws5201985 51CTO博客,原文链接:http://blog.51cto.com/wws5201985/740602,如需转载请自行联系原作者
目录
相关文章
|
存储 SQL Oracle
Oracle使用expdp/impdp实现全库导入导出的整体流程
Oracle的全库导入,首先一点必须先创建数据库,创建了数据库,才能往该数据库导入所有数据。相对来说,使用Oracle进行数据导入导出还很有些“麻烦”的,大多数资料上来就是......
6011 0
Oracle使用expdp/impdp实现全库导入导出的整体流程
|
存储 设计模式 Oracle
Oracle跨数据库实现定时同步指定表中的数据
Oracle跨数据库实现定时同步指定表中的数据
|
存储 SQL Oracle
跨Oracle数据库实现表级别的实时同步
跨Oracle数据库实现表级别的实时同步
|
SQL Oracle 关系型数据库
Oracle OS认证与密码文件认证(操作系统认证、口令文件认证、创建密码文件)
Oracle OS认证与密码文件认证(操作系统认证、口令文件认证、创建密码文件)
467 0
|
Oracle Java 关系型数据库
oracle实现主键自增长及自动生成策略
oracle实现主键自增长及自动生成策略
467 0
|
Oracle 关系型数据库 Linux
Oracle RAC:多路径配置Centos操作系统
Centos操作系统多路径配置
463 0
|
Oracle 关系型数据库 Windows
oracle学习29-检查操作系统版本和查询表中修改数据
oracle学习29-检查操作系统版本和查询表中修改数据
162 0
|
SQL Oracle 关系型数据库
SpringBoot整合oceanbase,实现oracle无缝切换到oceanbase
随着去“IOE”化的潮流,近些年来,许多与国家相关的项目不约而同到地往”国产化“方向靠拢,不可避免地,一些项目可能需要进行数据库迁移。
966 0
SpringBoot整合oceanbase,实现oracle无缝切换到oceanbase
|
Oracle 关系型数据库 数据库

推荐镜像

更多