你好,游客 登录 注册 搜索
背景:
阅读新闻

Oracle IO架构

[日期:2017-01-20] 来源:Linux社区  作者:Linux [字体: ]

等待事件从Oracle 7.0提出,真是一个伟大的想法,从此数据库对我们来说不是一个黑盒。

db file sequential read 数据文件单块读,指的是从数据文件中获取一个单块的信息。最能让人想到的是索引回表,当然全表扫描也可能产生单块读,因为不是所有的全表扫描都能多块读。

db file scattered read 多块读,最大块数由db_file_multiblock_read_count定义,此参数通常与操作系统IO大小一致,操作系统IO一般是512K或1MB。

direct path read 直接路径读,是指数据不加载到数据缓冲区(SGA的一块区域),直接加载到PGA。db file sequential read和db file scattered read都是先将数据加载到数据缓存区。直接路径读避免了数据缓存区管理的开销和争用(这是它存在的原因),但读取的数据不能被其他的进程使用,换言之,其他进程碰巧需要相同的块,需要从磁盘重新读取。一下场景会使用直接路径读:

执行临时段IO时总是使用直接路径读;并行查询时。

直接路径读可以是单块读也可以是多块读,执行有索引的单块读时,Oracle偏好缓存IO,因为块很可能会被重用。通常直接路径路径读更常用多块读。

direct path read/write temp,当PGA没有足够的内存时,就会用到临时段。

db file parallel write, DBWR IO被登记为此事件。DML操作默认情况下会修改数据缓存区的数据库,等待检查点到来将脏块写入到磁盘。

direct path write,直接路径写,数据从PGA直接插入到数据文件,不经过数据缓存区。用append或者并行。

log file parallel write,大部分重做日志会被注册为此事件。当重做日志初始化一个日志文件,会登记log file single write和 log file sequential read.重做日志记录刷到磁盘时,会有log file sync,这是一个重要指标,通常平均时间超过20ms,应用系统就会有严重问题了。

log archive I/O 归档日志写被登记为此事件。归档进程读取非活动的重做日志并写入到归档日志,重做日志读登记为log file sequential read.

flashback log file writes,当恢复写进程写入闪回日志,会登记为此事件。

control file parallel write,control file sequential read,控制文件IO登记的等待事件。

更多Oracle相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12

本文永久更新链接地址http://www.linuxidc.com/Linux/2017-01/139743.htm

linux
相关资讯       Oracle IO架构  Oracle IO 
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数

       

评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款