电脑故障

位置:IT落伍者 >> 电脑故障 >> 浏览文章

PCTFREE与PCTUSED对高性能和有效地重新使用表块的策略


发布日期:2018/6/24
 

PCTFREE=(Average Row SizeInitial Row Size)*/Average Row Size

PCTUSED=(PCTFREE) Average Row Size * /Availabe Data Space

Oracle的其中一个优点时它可以管理每个表空间中的自由空间Oracle负责处理表和索引的空间管理这样就可以让我们无需懂得Oracle的表和索引的内部运作不过对于有经验的Oracle调优专家来说他需要懂得Oracle是如何管理表的extent和空闲的数据块对于调整拥有高的insert或者update的系统来说这是非常重要的

要精通对象的调整你需要懂得freelists和freelist组的行为它们和pctfree及pctused参数的值有关这些知识对于企业资源计划(ERP)的应用是特别重要的因为在这些应用中不正确的表设置通常是DML语句执行慢的原因

对于初学者来说最常见的错误是认为默认的Oracle参数对于所有的对象都是最佳的除非磁盘的消耗不是一个问题否则在设置表的pctfree和pctused参数时就必须考虑平均的行长和数据库的块大小这样空的块才会被有效地放到freelists中当这些设置不正确时那些得到的freelists也是dead因为它们没有足够的空间来存储一行这样将会导致明显的处理延迟

Freelists对于有效地重新使用Oracle表空间中的空间是很重要的它和pctfree及pctused这两个存储参数的设置直接相关如果将pctused设置为一个高的值这时数据库就会尽快地重新使用块不过高性能和有效地重新使用表的块是对立的在调整Oracle的表格和索引时需要认真考虑究竟需要高性能还是有效的空间重用并且据此来设置表的参数以下我们来看一下这些freelists是如何影响Oracle的性能的

当有一个请求需要插入一行到表格中时Oracle就会到freelist中寻找一个有足够的空间来容纳一行的块你也许知道freelist串是放在表格或者索引的第一个块中这个块也被称为段头(segment header)pctfree和pctused 参数的唯一目的就是为了控制块如何在freelists中进出虽然freelist link和 unlink是简单的Oracle功能不过设置freelist link (pctused) 和unlink (pctfree) 对Oracle的性能确实有影响

由DBA的基本知识知道pctfree参数是控制freelist unlinks的(即将块由freelists中移除)设置pctfree= 意味着每个块都保留%的空间用作行扩展pctused参数是控制freelist relinks的设置pctused=意味着只有在块的使用低于%时才会回到表格的freelists中

许多新手对于一个块重新回到freelists后的处理都有些误解其实一旦由于一个删除的操作而令块被重新加入到freelist中它将会一直保留在freelist中即使空间的使用超过了%只有在到达pctfree时才会将数据块由freelist中移走

表格和索引存储参数设置的要求总结

以下的一些规则是用来设置freelists freelist groups pctfree和pctused存储参数的你也知道pctused和pctfree的值是可以很容易地通过alter table命令修改的一个好的DBA应该知道如何设置这些参数的最佳值

有效地使用空间和高性能之间是有矛盾的而表格的存储参数就是控制这个方面的矛盾

对于需要有效地重新使用空间可以设置一个高的pctused值不过副作用是需要额外的I/O一个高的pctused值意味着相对满的块都会放到freelist中因此这些块在再次满之前只可以接受几行记录从而导致更多的I/O

追求高性能的话可以将pctused设置为一个低的值这意味着Oracle不会将数据块放到freelists中直到它几乎是空的那么块将可以在满之前接收更多的行因此可以减少插入操作的I/O要记住Oracle扩展新块的性能要比重新使用现有的块高对于Oracle来说扩展一个表比管理freelists消耗更少的资源

让我们来回顾一下设置对象存储参数的一些常见规则

.经常将pctused设置为可以接收一条新行对于不能接受一行的free blocks对于我们来说是没有用的如果这样做将会令Oracle的性能变慢因为Oracle将在扩展表来得到一个空的块之前企图读取dead的free block

.表格中chained rows的出现意味着pctfree太低或者是db_block_size太少在很多情况下RAW和LONG RAW列都很巨大以至超过了Oracle的最大块的大小这时chained rows是不可以避免的

.如果一个表有同时插入的SQL语句那么它需要有同时删除的语句运行单一个一个清除的工作将会把全部的空闲块放到一个freelist中而没有其它包含有任何空闲块的freelists出现

.freelist参数应该设置为表格同时更新的最大值例如如果在任何时候某个表最多有个用户执行插入的操作那么该表的参数应该设置为freelists=

应记住的是freelist groups参数的值只是对于Oracle Parallel Server和Real Application Clusters才是有用的对于这类Oraclefreelist groups应该设置为访问该表格的Oracle Parallel Server实例的数目

上一篇:TCP/IP远程访问操作

下一篇:j2me创意--Wap浏览器的源代码