文档主要来自oracle官方文档performance 8.3章节

Oracle数据库提供了Orion,一种 I/O校准工具。Orion是预测Oracle数据库性能的工具,无需安装Oracle或创建数据库。与其他 I/O校准工具不同,Oracle Orion专门用于使用与Oracle相同的 I/O软件堆栈来模拟Oracle数据库 I/O工作负载。Orion还可以模拟Oracle自动存储管理所执行的条带化的效果。

1、先决条件
在运行 I/O 校准之前,请确保满足以下要求:
用户必须被授予SYSDBA特权
timed_statistics 必须设置为 TRUE
异步 I/O 必须启用

当使用文件系统,异步 I/O 可以通过设置来启用FILESYSTEMIO_OPTIONS初始化参数SETALL。

COL NAME FORMAT A50
SELECT NAME,ASYNCH_IO FROM V$DATAFILE F,V$IOSTAT_FILE I
WHERE F.FILE#=I.FILE_NO
AND FILETYPE_NAME='Data File';

2、运行 I/O 校准

Oracle数据库的I/O校准功能可以使用DBMS_RESOURCE_MANAGER.CALIBRATE_IO程序。
此过程向数据库文件发出I/O密集型只读工作负载(由1兆字节的随机I/O组成),以确定最大IOPS(每秒I/O请求)和MBPS(兆字节I/O每秒),可以由存储子系统维持

I/O校准分两步进行:
2.1 在 I/O 校准的第一步中DBMS_RESOURCE_MANAGER.CALIBRATE_IO过程时,过程将发出随机数据库块大小的读取(默认情况下,为8 KB),以便从所有数据库实例的所有数据文件中读取。
此步骤在输出参数max_iops中提供数据库可以承受的最大IOPS 。该值max_iops是OLTP数据库的重要指标。输出参数actual_latency为此工作负载提供平均延迟。
当需要特定的目标延迟时,可以使用输入参数指定目标延迟max_latency(指定数据库块大小的IO请求的最大可容忍延迟(以毫秒为单位))。

2.2 校准的第二步使用DBMS_RESOURCE_MANAGER.CALIBRATE_IO过程问题随机,1 MB读取所有数据库实例中的所有数据文件。
第二步产生输出参数max_mbps,该参数指定数据库可以承受的I / O的最大MBPS。这一步为数据仓库提供了一个重要的指标。
如果用户提供num_physical_disks输入参数(指定数据库存储系统中物理磁盘的大致数量),那么校准运行更有效。
由于运行 I/O工作负载的开销,I/O校准只能在数据库处于空闲状态或在非高峰时段执行,以尽量减少I / O工作负载对正常数据库工作负载的影响。
要运行 I/O 校准并评估Oracle数据库使用的存储子系统的I/O功能,请使用DBMS_RESOURCE_MANAGER.CALIBRATE_IO程序。

当运行DBMS_RESOURCE_MANAGER.CALIBRATE_IO程序,请考虑以下事项:
1、一次只能在使用相同存储子系统的数据库上运行一次校准。如果同时在使用相同存储子系统的单独数据库上运行校准,则校准将失败。
2、停顿数据库以最小化实例上的I/O。
3、 对于Oracle Real Application Clusters(Oracle RAC)配置,确保打开所有实例以跨节点校准存储子系统。
4、对于Oracle Real Application Clusters(Oracle RAC)数据库,同时从所有实例生成工作负载。
5、 该num_physical_disks输入参数是可选。通过将num_physical_disks参数设置为数据库存储系统中物理磁盘的近似数量,校准可以更快,更准确。
6、 在某些情况下,数据文件可以使用异步I/O,但用于提交异步I/O 的I/O子系统可能会最大化,并且I/O校准无法继续。在这种情况下,请参阅端口特定文档以获取有关检查系统上异步I/O的最大限制的信息。
在I/O校准过程中的任何时候,您都可以在V$IO_CALIBRATION_STATUS视图中查询校准状态。I/O校准成功完成后,您可以在DBA_RSRC_IO_CALIBRATE表格中查看结果。
select * from V$IO_CALIBRATION_STATUS;

select * from DBA_RSRC_IO_CALIBRATE;

官方模板如下:

SET SERVEROUTPUT ON
DECLARE
lat INTEGER;
iops INTEGER;
mbps INTEGER;
BEGIN
DBMS_RESOURCE_MANAGER.CALIBRATE_IO (<DISKS>, <MAX_LATENCY>, iops, mbps, lat);
DBMS_OUTPUT.PUT_LINE ('max_iops = ' || iops);
DBMS_OUTPUT.PUT_LINE ('latency = ' || lat);
dbms_output.put_line('max_mbps = ' || mbps);
end;
/

我测试的如下:

SET SERVEROUTPUT ON
DECLARE
lat INTEGER;
iops INTEGER;
mbps INTEGER;
BEGIN
DBMS_RESOURCE_MANAGER.CALIBRATE_IO (2, 10, iops, mbps, lat);
DBMS_OUTPUT.PUT_LINE ('max_iops = ' || iops);
DBMS_OUTPUT.PUT_LINE ('latency = ' || lat);
dbms_output.put_line('max_mbps = ' || mbps);
end;
/

结果如下:

max_iops = 13032
latency = 10
max_mbps = 253

PL/SQL procedure successfully completed.

Oracle Orion tool check io(ORACLE Orion 工具查看以及校验IO)的更多相关文章

  1. 介绍Oracle自带的一些ASM维护工具 (kfod/kfed/amdu)

    1.前言 ASM(Automatic Storage Management)是Oracle主推的一种面向Oracle的存储解决方式,它是一个管理卷组或者文件系统的软件.眼下已经被RAC环境广泛使用,可 ...

  2. 【ASM】介绍Oracle自带的一些ASM维护工具 (kfod/kfed/amdu)

    转自:http://blog.csdn.net/wenzhongyan/article/details/47043253 非常感谢作者的文章,很有价值!至此转载,非常感谢 1.前言 ASM(Autom ...

  3. [置顶] Oracle 11g R2 RAC:使用 srvctl 工具管理 service 资源

    1.使用 srvctl 工具创建 service 资源 srvctl add service -d db_unique_name -s service_name {-r "preferred ...

  4. One simple health check for oracle with sql

    There are some sqls which is used for check the oracle database's health condition. ------numbers of ...

  5. Oracle 11g dataguard check RTA(real time apply)

    Oracle 11g dataguard check RTA(real time apply) 2017年8月24日 16:38 环境:oracle 11.2.0.1 OEL 5.8 注:以下操作都在 ...

  6. 例举在诊断Oracle性能问题时,常用的工具、方法

    例举在诊断Oracle性能问题时,常用的工具.方法 解答: 1)简单一点的可以用toad及dbartisan这样的工具. 2)纯做性能监测,比较出色的有spolight和emc的I3,这两个软件都比较 ...

  7. 在代码生成工具Database2Sharp中使用ODP.NET(Oracle.ManagedDataAccess.dll)访问Oracle数据库,实现免安装Oracle客户端,兼容32位64位Oracle驱动

    由于我们开发的辅助工具Database2Sharp需要支持多种数据库,虽然我们一般使用SQLServer来开发应用较多,但是Oracle等其他数据库也是常用的数据库之一,因此也是支持使用Oracle等 ...

  8. Linux 上Oracle RAC 10g 升级到 Oracle RAC 11g

    了解如何在 Oracle Enterprise Linux 5 上逐步将 Oracle RAC 10g 第 2 版升级到 Oracle RAC 11g. Oracle 数据库 11g(即,新一代网格计 ...

  9. 【转】:Oracle Linux6.9下安装Oracle 11.2.0.4.0及psu补丁升级

    为方便截图,本文操作都在vmware虚拟机上完成. 目录: 1.操作系统安装 2.数据库安装 3.PSU补丁升级卸载   part1 操作系统安装 Oracle (Enterprise) Linux ...

随机推荐

  1. freemarker获取封装类中对象的属性

    freemarker获取封装类中对象的属性 1.设计思路 (1)封装学生类 (2)创建数据模型 (3)新建student.ftl (4)运行Junit测试文件,生成HTML文件 2.封装学生类 Stu ...

  2. Linux显示工作路径

    Linux显示工作路径 youhaidong@youhaidong-ThinkPad-Edge-E545:~$ pwd /home/youhaidong

  3. Exynos4412交叉编译环境搭建

    Exynos4412交叉编译环境搭建 交叉编译:在PC机(x86平台)上开发程序,在ARM板上运行,提高开发.编译速度. 环境: Tiny4412SDK1506开发板 需要软件: arm-linux- ...

  4. 芝麻HTTP: 1.9.3-Scrapyd-Client的安装

    在将Scrapy代码部署到远程Scrapyd的时候,第一步就是要将代码打包为EGG文件,其次需要将EGG文件上传到远程主机.这个过程如果用程序来实现,也是完全可以的,但是我们并不需要做这些工作,因为S ...

  5. OpenStack_I版 4.Dashboard部署

    由python的DjangoWeb框架开发的   使用keystone默认的角色来访问各种服务   Dashboard安装       Dashboard是openstack的Web管理界面,需要将它 ...

  6. html点小图看大图最快捷的方法

    方法一: <td> <a href="{$vo.show_img}" target="_blank"><img style=&qu ...

  7. C#构造函数与析构函数--C#基础

    1.构造函数 1)构造函数没有返回值,也不能写void,必须是public 修饰符 2)构造函数和类名相同 3)构造函数也是可以重载的 public Clerk(string name,Gender ...

  8. .NET平台开源项目速览(21)Cron任务调度CronNET

    如果用知乎,可以关注专栏:.NET开源项目和PowerBI社区 Quartznet大名鼎鼎应该很少有人不知道,相关的开源项目很多,不过那东东对新手来说,有点晦涩,加上哪个Cron表达式,可能一进去云里 ...

  9. 如何控制Bean对象的作用域,默认作用域是什么

    1.可以通过<bean>定义的scope属性指定Bean对象的作用域或者使用注解@Scope指定Bean对象的作用域. 2.默认Bean对象的作用域为singleton.

  10. 【BZOJ1009】GT考试(KMP算法,矩阵快速幂,动态规划)

    [BZOJ1009]GT考试(KMP算法,矩阵快速幂,动态规划) 题面 BZOJ 题解 看到这个题目 化简一下题意 长度为\(n\)的,由\(0-9\)组成的字符串中 不含串\(s\)的串的数量有几个 ...