浅析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

相关文章

MySQL中删除重复数据SQL的三种写法

《MySQL中删除重复数据SQL的三种写法》:本文主要介绍MySQL中删除重复数据SQL的三种写法,文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下... 目录方法一:使用 left join + 子查询删除重复数据(推荐)方法二:创建临时表(需分多步执行,逻辑清晰,但会

Mysql 中的多表连接和连接类型详解

《Mysql中的多表连接和连接类型详解》这篇文章详细介绍了MySQL中的多表连接及其各种类型,包括内连接、左连接、右连接、全外连接、自连接和交叉连接,通过这些连接方式,可以将分散在不同表中的相关数据... 目录什么是多表连接?1. 内连接(INNER JOIN)2. 左连接(LEFT JOIN 或 LEFT

mysql重置root密码的完整步骤(适用于5.7和8.0)

《mysql重置root密码的完整步骤(适用于5.7和8.0)》:本文主要介绍mysql重置root密码的完整步骤,文中描述了如何停止MySQL服务、以管理员身份打开命令行、替换配置文件路径、修改... 目录第一步:先停止mysql服务,一定要停止!方式一:通过命令行关闭mysql服务方式二:通过服务项关闭

SQL Server数据库磁盘满了的解决办法

《SQLServer数据库磁盘满了的解决办法》系统再正常运行,我还在操作中,突然发现接口报错,后续所有接口都报错了,一查日志发现说是数据库磁盘满了,所以本文记录了SQLServer数据库磁盘满了的解... 目录问题解决方法删除数据库日志设置数据库日志大小问题今http://www.chinasem.cn天发

mysql主从及遇到的问题解决

《mysql主从及遇到的问题解决》本文详细介绍了如何使用Docker配置MySQL主从复制,首先创建了两个文件夹并分别配置了`my.cnf`文件,通过执行脚本启动容器并配置好主从关系,文中还提到了一些... 目录mysql主从及遇到问题解决遇到的问题说明总结mysql主从及遇到问题解决1.基于mysql

MySQL的索引失效的原因实例及解决方案

《MySQL的索引失效的原因实例及解决方案》这篇文章主要讨论了MySQL索引失效的常见原因及其解决方案,它涵盖了数据类型不匹配、隐式转换、函数或表达式、范围查询、LIKE查询、OR条件、全表扫描、索引... 目录1. 数据类型不匹配2. 隐式转换3. 函数或表达式4. 范围查询之后的列5. like 查询6

Linux下MySQL8.0.26安装教程

《Linux下MySQL8.0.26安装教程》文章详细介绍了如何在Linux系统上安装和配置MySQL,包括下载、解压、安装依赖、启动服务、获取默认密码、设置密码、支持远程登录以及创建表,感兴趣的朋友... 目录1.找到官网下载位置1.访问mysql存档2.下载社区版3.百度网盘中2.linux安装配置1.

PostgreSQL如何用psql运行SQL文件

《PostgreSQL如何用psql运行SQL文件》文章介绍了两种运行预写好的SQL文件的方式:首先连接数据库后执行,或者直接通过psql命令执行,需要注意的是,文件路径在Linux系统中应使用斜杠/... 目录PostgreSQ编程L用psql运行SQL文件方式一方式二总结PostgreSQL用psql运

提示:Decompiled.class file,bytecode version如何解决

《提示:Decompiled.classfile,bytecodeversion如何解决》在处理Decompiled.classfile和bytecodeversion问题时,通过修改Maven配... 目录问题原因总结问题1、提示:Decompiled .class file,China编程 bytecode

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti