浅析db file sequential read/db file scattered read/ direct path read

2023-11-01 13:10

本文主要是介绍浅析db file sequential read/db file scattered read/ direct path read,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!



事件概述
Db file sequential read
当数据库发生顺序读时会出现此等待事件,重建控制文件,dump数据文件头,读取数据库文件头也会引起此类事件。
解决办法
1.sql使用了选择性较差的索引
2.增大buffer cache
3.考虑簇,使数据物理的放置在一起
4.分区表,减少数据访问量
5.把数据文件放在IO较空闲的磁盘上
参考文档
WAITEVENT: "db file sequential read" Reference Note (文档 ID 34559.1)
Resolving Issues Where Application Queries are Waiting Too Frequently for 'db file sequential read' Operations (文档 ID 1475825.1)




file scattered read
事件概述

db file sequential read 类似,但是会话读取的是多个数据块到多个不连续的内存地址上。这个等待事件由于会话等待multiblock IO,特别是FULL  TABLE SCAN or INDEX FAST FULL SCAN.

1由于低效的sql

2.低下的IO

解决办法

1.通过v$sqlarea查找是否有sql占用了大量的物理读

2.考虑分区以减少访问的数据量

3.检查对象是否是高HWM

4.考虑压缩以减少访问的块数

5.检查高读取的表的并行度

参考文档

WAITEVENT: "db file scattered read" Reference Note (文档 ID 34558.1)

direct path read
事件概述
数据库直接读取数据到pga时会发生此等待事件。如果支持异步IO,数据库会提交IO请求并继续执行,IO请求会等待,这个时候就会有direct path read 直到IO请求完成。如果没有使用异步IO,那么IO请求直到事务完成,会话会稍晚的获得IO数据,但会产生direct path read等待。



解决办法
1.如果该等待事件的读取文件属于临时表空间,坚持合适的排序sql
2.确保DISK_ASYNCH_IO=TRUE,此参数虽不能减少等待事件的发生,但是可以减少elapsed time
3.确保异步IO系统配置正确
4.查找IO占用较多的SQL,减少IO消耗
5.确保没有IO bound
参考文档
WAITEVENT: "direct path read" Reference Note (文档 ID 50415.1)

区别:
p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px 'Times New Roman'; color: #000000; -webkit-text-stroke: #000000} span.s1 {font-kerning: none} span.s2 {font: 12.0px 'Songti SC'; font-kerning: none} span.Apple-tab-span {white-space:pre}

db file sequential read,db file scatterd read,direct read 的区别:

? db file sequential read (single block read into one SGA buffer)

? db file scattered read (multiblock read into many discontinuous SGA buffers)

? direct read (single or multiblock read into the PGA, bypassing the SGA)








来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31461640/viewspace-2141283/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/31461640/viewspace-2141283/

这篇关于浅析db file sequential read/db file scattered read/ direct path read的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/323201

相关文章

浅析Java如何保护敏感数据

《浅析Java如何保护敏感数据》在当今数字化时代,数据安全成为了软件开发中至关重要的课题,本文将深入探讨Java安全领域,聚焦于敏感数据保护的策略与实践,感兴趣的小伙伴可以了解下... 目录一、Java 安全的重要性二、敏感数据加密技术(一)对称加密(二)非对称加密三、敏感数据的访问控制(一)基于角色的访问

一文详解如何查看本地MySQL的安装路径

《一文详解如何查看本地MySQL的安装路径》本地安装MySQL对于初学者或者开发人员来说是一项基础技能,但在安装过程中可能会遇到各种问题,:本文主要介绍如何查看本地MySQL安装路径的相关资料,需... 目录1. 如何查看本地mysql的安装路径1.1. 方法1:通过查询本地服务1.2. 方法2:通过MyS

Mysql数据库中数据的操作CRUD详解

《Mysql数据库中数据的操作CRUD详解》:本文主要介绍Mysql数据库中数据的操作(CRUD),详细描述对Mysql数据库中数据的操作(CRUD),包括插入、修改、删除数据,还有查询数据,包括... 目录一、插入数据(insert)1.插入数据的语法2.注意事项二、修改数据(update)1.语法2.有

SQL Server中的PIVOT与UNPIVOT用法具体示例详解

《SQLServer中的PIVOT与UNPIVOT用法具体示例详解》这篇文章主要给大家介绍了关于SQLServer中的PIVOT与UNPIVOT用法的具体示例,SQLServer中PIVOT和U... 目录引言一、PIVOT:将行转换为列核心作用语法结构实战示例二、UNPIVOT:将列编程转换为行核心作用语

SQL 外键Foreign Key全解析

《SQL外键ForeignKey全解析》外键是数据库表中的一列(或一组列),用于​​建立两个表之间的关联关系​​,外键的值必须匹配另一个表的主键(PrimaryKey)或唯一约束(UniqueCo... 目录1. 什么是外键?​​ ​​​​2. 外键的语法​​​​3. 外键的约束行为​​​​4. 多列外键​

MySQL精准控制Binlog日志数量的三种方案

《MySQL精准控制Binlog日志数量的三种方案》作为数据库管理员,你是否经常为服务器磁盘爆满而抓狂?Binlog就像数据库的“黑匣子”,默默记录着每一次数据变动,但若放任不管,几天内这些日志文件就... 目录 一招修改配置文件:永久生效的控制术1.定位my.cnf文件2.添加核心参数不重启热更新:高手应

MySQL中SQL的执行顺序详解

《MySQL中SQL的执行顺序详解》:本文主要介绍MySQL中SQL的执行顺序,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql中SQL的执行顺序SQL执行顺序MySQL的执行顺序SELECT语句定义SELECT语句执行顺序总结MySQL中SQL的执行顺序

MySQL中like模糊查询的优化方案

《MySQL中like模糊查询的优化方案》在MySQL中,like模糊查询是一种常用的查询方式,但在某些情况下可能会导致性能问题,本文将介绍八种优化MySQL中like模糊查询的方法,需要的朋友可以参... 目录1. 避免以通配符开头的查询2. 使用全文索引(Full-text Index)3. 使用前缀索

MySQL中的两阶段提交详解(2PC)

《MySQL中的两阶段提交详解(2PC)》:本文主要介绍MySQL中的两阶段提交(2PC),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录引言两阶段提交过程sync_binlog配置innodb_flush_log_at_trx_commit配置总结引言在Inn

Docker安装MySQL镜像的详细步骤(适合新手小白)

《Docker安装MySQL镜像的详细步骤(适合新手小白)》本文详细介绍了如何在Ubuntu环境下使用Docker安装MySQL5.7版本,包括从官网拉取镜像、配置MySQL容器、设置权限及内网部署,... 目录前言安装1.访问docker镜像仓库官网2.找到对应的版本,复制右侧的命令即可3.查看镜像4.启