Oracle IO性能测试工具Orion详解

 

1Orion概述

 

1.1 Orion说明

 

Orion是Oracle提供的IO性能测试工具,运行该工具不需要安装oracle database软件或创建数据库。它可以模拟Oracle数据库的IO负载,也可以用来仿真ASM的条带化的功能。测试随机或顺序访问指定大小块的IO性能,性能指标包括:IOPS,MBPS,Latency(延迟时间)。

从Oracle Database 11g开始,Orion工具被集成到GI和Database软件中,所以在$GRID_HOME/bin和$ORACLE_HOME/bin目录下都可以找到这个工具。

 

1.2 Orion优缺点

 

优点

 

1) 可以灵活指定IO负载,如小的随机IO,大的连续IO等。

2) 不需要运行load runner以及录制相关的动作。

3) 不需要运行oracle数据库以及准备大量的测试数据就能模拟oracle数据库运行时的IO负载。

4) 测试结果更具有代表性,如随机IO测试中,该软件可以让存储的命中率接近为0,而更仿真出了磁盘的真实的IOPS,而其它的压力测试工具很难做到这些,并不能直接得到磁盘的IOPS及MBPS值。

5) 可以根据需求制定读写比例。

 

缺点

 

1) 无法根据实际情况自定义测试时长及负载情况,整个测试过程都是自动完成。

2) 无法进行一些自定义的操作类型,如表的全表扫描、全索引扫描、数据入库测试等。

 

2开始使用Orion

 
 

1、 选择一个名称作为-testname 的参数值,此参数为orion 的运行指定一个唯一的标识符,如果不指定该参数,将以orion为名称运行,生成的结果文件也以该名称为文件名的前面部分。

 

2、 基于上一步骤中的testname指定的名称,创建Orion 输入文件,如:创建文件名为mystest.lun的文件,在文件中写入需要测试的设备名称。

 

如下所示:

/dev/raw/raw1

/dev/raw/raw2

/dev/sdb1

/dev/sdc1

 

3、 确认需要测试的设备能够被访问。

$ dd if=/dev/raw/raw1 of=/dev/null bs=32k count=1024

 

4、 因orion的测试依赖于异步IO,需确认平台中已经安装异步IO的类库,类库必须在标准的目录或可以通过shell环境的库路径变量来访问。Linux 2.6内核版本以上默认已经安装了libaio的RPM包。

 

5、 模拟OLTP环境进行测试。

./orion_linux_x86 -run oltp -testname mytest

 

3在实际应用中的测试

 
 

本次测试的磁盘设备是多台服务器的本地硬盘通过分布式软件虚拟出来的磁盘。主要测试读的性能,分3种场景进行测试。

 

1、8K随机读

 

./orion_linux_x86-64 -run advanced \

-num_large 0 -size_small 8 -type rand \

-simulate raid0 -write 0 -duration 120 \

-matrix row –testname mytest

ORION: ORacle IO Numbers -- Version 11.1.0.7.0

mytest_20151029_1324

Test will take approximately 23 minutes

Larger caches may take longer

 

这里显示测试时间为23分钟,ORION测试时长无法控制。

 

测试完成后,生成下面几个结果文件:

 

mytest_20151029_1324_trace.txt     --测试过和的详细信息

mytest_20151029_1324_summary.txt   --测试结果的总体概要

mytest_20151029_1324_mbps.csv      --大的IOs的性能结果 MBPS(吞吐量)

mytest_20151029_1324_lat.csv       --小的IOs的延时

mytest_20151029_1324_iops.csv --小的IOs的性能结果IOPS(每秒IO次数)

这次测试没有指定大的IO,所以mpbs.csv文件没有生成内容

Name: /dev/sdy1 Size: 105225974784

Name: /dev/sdz1 Size: 105225974784

50 FILEs found.

Maximum Small IOPS=28394 @ Small=120 and Large=0  --最大IOPS为28394

Minimum Small Latency=0.17 @ Small=1 and Large=0  --最小延时为0.17ms

 

生成的IOPS曲线图如下:

 

 

2、8K随机写

 

./orion_linux_x86-64 -run advanced \

-num_large 0 -size_small 8 -type rand \

-simulate raid0 -write 100 -duration 120 \

-matrix row

 

 

3、1M顺序读        

 

./orion_linux_x86-64 -run advanced \

-num_small 0 -size_large 1024 -type seq \

-simulate raid0 -write 0 -duration 120 \

-matrix col

 

生成的MBPS图如下所示:

 

 

4问题与解决方法

 
 

在此次测试的过程中,第一次测试进行到一半时,报了异步IO的错误,检查相关的LIB包及环境均正常,然后在一台安装的oracle数据库的机器上测试却正常完成,对比发现sysctl.conf参数文件配置的问题,增加以下配置后,问题得到解决。

 

作者介绍:黄石有

 

  • 新炬网络公司高级技术专家。
  • 拥有十年以上oracle数据库管理、维护及开发经验,具有丰富的数据库日常维护及故障处理经验,具备较强的sql优化能力。

本文来自合作伙伴"DBAplus",原文发布时间:2016-01-05

时间: 2024-10-28 09:04:01

Oracle IO性能测试工具Orion详解的相关文章

Oracle数据操作和控制语言详解_oracle

正在看的ORACLE教程是:Oracle数据操作和控制语言详解.SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML, 数据定义语言DDL,数据控制语言DCL.其中用于定义数据的结构,比如 创建.修改或者删除数据库:DCL用于定义数据库用户的权限:在这篇文章中我将详细讲述这两种语言在Oracle中的使用方法.  DML语言 DML是SQL的一个子集,主要用于修改数据,下表列出了ORACLE支持的DML语句. 插入数据 INSERT语句常常用于向表中插入行,行中可以有特殊数据字段,或者可

PowerShell攻防进阶篇:nishang工具用法详解

本文讲的是PowerShell攻防进阶篇:nishang工具用法详解, 1.简介 Nishang是一款针对PowerShell的渗透工具.说到渗透工具,那自然便是老外开发的东西.国人开发的东西,也不是不行,只不过不被认可罢了.不管是谁开发的,既然跟渗透有关系,那自然是对我们有帮助的,学习就好.来源什么的都不重要.总之,nishang也是一款不可多得的好工具.非常的好用. 2.简单的安装与问题处理   先到github上去下载nishang,可以使用git命令直接下载,如果没有装的话下载zip文件

Oracle 12c多租户特性详解:全局用户与本地用户的原理与维护

(题图来自Oracle VP , Sally Piao的摄影佳作,感谢摄影师授权) 编辑手记:这一节我们将介绍多租户架构中用户及权限的变化,全局用户和本地用户,管理方式和内部实现,这篇文章来自<深入解析Oracle>一书的摘录. 前情回顾:Oracle 12c多租户特性详解:从Schema到PDB的变化与隔离 COMMON 和 Local 用户 无论在 CDB 和 Non-CDB 数据库中,用户都拥有一个 Schema,拥有一系列的 Schema 对象,在 CDB 中由于 PDB 的引入,用户

Oracle 静态监听注册详解

Oracle 静态监听注册详解        网上有很多关于oracle 监听静态注册的文章,但大多都是简单说说,并没有详细的例子,这里,将结合linux as4 下的oracle 10gR2.0.1 举一个具体的例子 1.在 $ORACLE_HOME/network/admin/listener.ora 文件中加入一个静态注册的节点 [oracle@prudent oracle]$ cd $ORACLE_HOME/network/admin [oracle@prudent admin]$ vi

Oracle数据操作和控制语言详解

oracle|控制|数据|详解 插入数据    INSERT语句常常用于向表中插入行,行中可以有特殊数据字段,或者可以用子查询从已存在的数据中建立新行.    列目录是可选的,缺省的列的目录是所有的列名,包括comlumn_id,comlumn_id可以在数据字典视图ALL_TAB_COLUMNS,USER_TAB_COLUMNS,或者DBA_TAB_COLUMNS中找到.    插入行的数据的数量和数据类型必须和列的数量和数据类型相匹配.不符合列定义的数据类型将对插入值实行隐式数据转换.NUL

Oracle数据操作和控制语言详解(三)

oracle|控制|数据|详解 建立和修改用户 CREATE USER 语句将建立一个用户.当一个用户连接到ORACLE数据库时,它必须被验证.ORACLE中验证有三种类型: Database external Global 缺省是数据库验证,当用户连接到数据库时,oracle将检测用户是否是数据库的合法用户,并且要提供正确的password.external验证,oracle将只检测用户是否是合法用户,password已经被网络或系统验证了.global验证也是只检测是否是合法用户,passw

Oracle存储过程和自定义函数详解_oracle

概述 PL/SQL中的过程和函数(通常称为子程序)是PL/SQL块的一种特殊的类型,这种类型的子程序可以以编译的形式存放在数据库中,并为后续的程序块调用. 相同点: 完成特定功能的程序 不同点:是否用return语句返回值. 举个例子: create or replace procedure PrintStudents(p_staffName in xgj_test.username%type) as cursor c_testData is select t.sal, t.comm from

Oracle数据操作和控制语言详解 (一)

oracle|控制|数据|详解 SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML, 数据定义语言DDL,数据控制语言DCL.其中用于定义数据的结构,比如 创建.修改或者删除数据库:DCL用于定义数据库用户的权限:在这篇文章中我将详细讲述这两种语言在Oracle中的使用方法. DML语言 DML是SQL的一个子集,主要用于修改数据,下表列出了ORACLE支持的DML语句. 语句 用途 INSERT 向表中添加行 UPDATE 更新存储在表中的数据 DELETE 删除行 SELECT

Oracle数据操作和控制语言详解(二)

oracle|控制|数据|详解 事务控制 事务控制包括协调对相同数据的多个同步的访问.当一个用户改变了另一个用户正在使用的数据时,oracle使用事务控制谁可以操作数据. 事务 事务表示工作的一个基本单元,是一系列作为一个单元被成功或不成功操作的SQL语句.在SQL和PL/SQL中有很多语句让程序员控制事务.程序员可以: 1.显式开始一个事物,选择语句级一致性或事务级一致性 2.设置撤销回滚点,并回滚到回滚点 3.完成事务永远改变数据或者放弃修改. 事务控制语句 语句 用途 Commit 完成事