数据库I/O上的等待事件怎么理解

58次阅读
没有评论

共计 1506 个字符,预计需要花费 4 分钟才能阅读完成。

这篇文章主要讲解了“数据库 I / O 上的等待事件怎么理解”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着丸趣 TV 小编的思路慢慢深入,一起来研究和学习“数据库 I / O 上的等待事件怎么理解”吧!

SQL select event#,name,parameter1,parameter2,parameter3 from v$event_name where name = control file sequential read  

当数据库需要读取控制文件上的信息时,会出现这个等待事件,因为控制文件的信息是顺序写的,所以读取的时候也是顺序的,因此称为控制文件顺序读,它经常发生在以下情况。

(1)备份控制文件。
(2)RAC 环境下不同实例之间控制文件的信息共享。
(3)读取控制文件的文件头信息。
(4)读取控制文件的其他信息。

这个等到事件的包含以下三个参数:
file#:要读取信息的控制文件的文件号。
block#:读取控制文件信息的起始数据块号。
blocks:需要读取的控制文件数据块数目。   

====================================================================
请求控制文件的更新的进程直到更新结束为止,其间等待 control file parallel write 事件
SQL select event#,name,parameter1,parameter2,parameter3 from v$event_name where name = control file parallel write  
 
这个等待事件包含三个参数:
files:Oracle 要写入的控制文件个数。
block#:写入控制文件的数据块数目。
requests:写入控制文件请求的 I / O 次数。

一般环境下,因为更新控制文件的次数不多,因此不怎么发生 control file parallel write 等待现象。但如下情况下可能发生与控制文件相关的争用。
日志文件切换经常发生时:
日志文件过小时,将经常发生日志文件的切换。每当发生日志文件切换时,需要对控制文件进行更新,所以 LGWR 进程等待 control file parallel write 事件的时间将延长。

检查点经常发生时:
MTTR 设定得过短或频繁发生人为的检查点时,CKPT 进程等待 control file parallel write 事件的时间将延长。

nologging 引起频繁的数据文件修改时:
对数据文件在 nologging 选项下执行修改工作时,为了修改 unrecoverable SCN 需要更新控制文件。这时,服务器进程将等待 control file parallel write 事件。

I/ O 系统的性能缓慢时:

最好是将控制文件位于独立的磁盘空间上,使用裸设备或 direct I/O。

control file parallel write 等待,通常与 control file sequential read 等待或 enq: CF – contention 等待一同出现的情况较多。enq: CF – contention 等待是在多个会话为了同时更新控制文件获得 CF 锁的过程中发生的。control file parallel write、control file sequential read、CF – contention 等待,全是因为过多的控制文件更新或 I / O 系统的性能问题引发的。

感谢各位的阅读,以上就是“数据库 I / O 上的等待事件怎么理解”的内容了,经过本文的学习后,相信大家对数据库 I / O 上的等待事件怎么理解这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是丸趣 TV,丸趣 TV 小编将为大家推送更多相关知识点的文章,欢迎关注!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-17发表,共计1506字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)