db_file_multiblock_read_count 的自动调整

简介: 转之Eygle的文章:http://www.eygle.com/archives/2009/03/db_file_multiblock_read_count_auto.html   关于这个参数,经过几多变化,在Oracle10gR2中终于修成了正果,实现了自动调整。

转之Eygle的文章:

 

 

关于这个参数,经过几多变化,在Oracle10gR2中终于修成了正果,实现了自动调整。

很久以前演过过这个参数,有过这样的记叙

初始化参数db_file_multiblock_read_count 影响Oracle在执行全表扫描时一次读取的block的数量.

 

db_file_multiblock_read_count的设置要受OS最大IO能力影响,也就是说,如果你系统的硬件IO能力有限,即使设置再大的db_file_multiblock_read_count也是没有用的。

理论上,最大db_file_multiblock_read_count和系统IO能力应该有如下关系:

Max(db_file_multiblock_read_count) = MaxOsIOsize/db_block_size

当然这个Max(db_file_multiblock_read_count)还要受Oracle的限制,
目前Oracle所支持的最大db_file_multiblock_read_count 值为128.

我们可以通过db_file_multiblock_read_count来测试Oracle在不同系统下,单次IO最大所能读取得数据量

 

这个参数的设置可能影响到CBO优化器的执行计划选择,所以Oracle通常缺省设置为16,不推荐设置高于32的值。


引用一段Kamus同学的描述:

db_file_multiblock_read_count曾经是一个经过热烈讨论的初始化参数。该参数只有在对表或者索引进行Full Scan的时候才起作用。

 

在Oracle10gR2以前的版本中,DBA必须根据db_block_size参数,以及应用系统的特性,来调整db_file_multiblock_read_count参数。该参数值将影响CBO在该产生何种SQL执行计划上的判断。

我们知道如下的公式,其中max I/O chunk size跟操作系统有关,但是Oracle文档中也指出大多数操作系统上该值为1M。

db_file_multiblock_read_count = max I/O chunk size / db_block_size

在Oracle10gR2之后的版本(10gR2和11g)中,Oracle数据库已经可以根据系统的IO能力以及Buffer Cache的大小来动态调整该参数值,Oracle建议不要显式设置该参数值。

 

在我的一个11.1.0.7的环境中,这个值被自动调整为73:


SQL> select * from v$version;

 

BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.1.0.7.0 - Production
PL/SQL Release 11.1.0.7.0 - Production
CORE    11.1.0.7.0      Production
TNS for Linux: Version 11.1.0.7.0 - Production
NLSRTL Version 11.1.0.7.0 - Production

SQL> show parameter multi

NAME                                TYPE        VALUE
------------------------------------ ----------- ------------------------------
db_file_multiblock_read_count        integer    73
parallel_adaptive_multi_user        boolean    TRUE

 

相关文章
|
监控 安全 数据可视化
浅谈下一代防火墙与Web应用防火墙的区别
浅谈下一代防火墙与Web应用防火墙的区别
386 0
|
API 调度
2.3.1 协程设计原理与汇编实现
2.3.1 协程设计原理与汇编实现
119 0
|
人工智能 数据可视化
用了这8款AI制作PPT软件,年终总结再也不是问题!
8款好用的AI生成PPT软件推荐,轻松解决你的年终总结!
|
存储 前端开发 JavaScript
PixiJS源码分析系列:第四章 响应 Pointer 交互事件(上篇)
PixiJS源码分析系列:第四章 响应 Pointer 交互事件(上篇)
|
Linux C# Android开发
一个开源、跨平台的.NET UI框架 - Avalonia UI
一个开源、跨平台的.NET UI框架 - Avalonia UI
644 3
|
开发工具 数据安全/隐私保护 git
Git使用经验总结3-删除远端提交记录
Git使用经验总结3-删除远端提交记录
524 0
|
数据安全/隐私保护
BUUCTF---misc--snake
BUUCTF---misc--snake
|
编解码 前端开发 开发者
构建响应式Web界面:现代前端开发的最佳实践
【2月更文挑战第16天】 在多设备浏览时代,为不同屏幕尺寸和分辨率构建兼容的Web界面成为前端开发者的核心挑战。本文深入探讨了响应式设计的理念、关键技术和最佳实践,旨在指导开发者通过灵活布局、媒体查询、弹性图片等技术手段,实现流畅的用户体验。通过分析真实案例,本文将提供一套行之有效的方法论,帮助前端工程师高效地构建和维护响应式Web项目。
230 2
|
存储 数据安全/隐私保护
scanf函数读取数据 & 清空缓冲区
scanf函数读取数据 & 清空缓冲区
581 0