`
blues1021
  • 浏览: 141344 次
  • 性别: Icon_minigender_1
  • 来自: 南宁
社区版块
存档分类
最新评论

Oracle PCTFREE和PCTUSED参数-DBA配置调优

 
阅读更多

调整Oracle的竞争
  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 un-links的(即将块由freelists中移除)。设置pctfree=10 意味着每个块都保留10%的空间用作行扩展,当data-block使用达到90%,freelist将un-links该数据块。 pctused参数是控制freelist re-links的。设置pctused=40意味着只有在块的使用低于40%时才会回到表格的freelists中 ,当然这是在PCTFREE参数作用un-links该数据块后。
    许多新手对于 一个块重新回到freelists后的处理都有些误解。其实,一旦由于一个删除的操作而令块被重新加入到freelist中,它将会一直保留在 freelist中即使空间的使用超过了60%,只有在到达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将在扩展表来得到一个空的块之前,企图读取5个"dead"的free block。

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

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

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

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

PCTFREE=(Average Row Size-Initial Row Size)*100/Average Row Size
  PCTUSED=(100-PCTFREE) -Average Row Size * 100/Availabe Data Space
个人觉得这两句表达有问题,也没有作用。
你怎么知道Average Row Size,Initial Row Size?而且表达也不清楚,计算单位应该按data-block。
这两个值通常在创建表和索引时指定:
CREATE TABLE<tablename>(row definitions ...)PCTFREE=20,PCTUSED=40;
PCTFREE+PCTUSED<=100就好,如果要求高性能重于空间利用率选择较高PCTFREE值和较低的PCTUSED值,反之则取反;Oracle10g默认的PCTFREE值为10,PCTUSED为40,当然具体的取值要经验支持。
刚想写一遍这方面的文章,借鉴了http://cjjwzs.iteye.com/blog/1136345

分享到:
评论

相关推荐

    DBA 应遵循的 Oracle 调优原则

    - 初始化参数如`PCTUSED`、`PCTFREE`等,可以影响行插入和更新的效率。 - 适当调整这些参数以优化存储空间的使用。 **2. 表分割** - 对大型表进行分割,可以减少表锁定时间,提高并发性能。 - 使用分区技术,...

    ORACLE_DBA面试

    - `PCTUSED`和`PCTFREE`的作用。 - 表与段、扩展区、块之间的关系。 - 表空间与数据文件的关系。 - 表空间的管理方式:手动管理与自动管理的区别。 #### 14. 系统资源管理和备份恢复 - **资源管理**:包括内存...

    Oracle企业级DBA培训资料

    2. 物理存储优化:通过调整表和索引的存储参数,如块大小、 pctfree 和 pctused,优化I/O性能。 3. 索引管理:选择合适的索引类型(B树、位图、函数索引等),创建和维护索引,以加速查询速度。 4. 分区技术:Oracle...

    Oracle企业DBA性能优化

    遵循一些基本规则可以显著提升查询效率,例如避免大表和全表扫描,充分利用优化索引,优化子查询,调整PCTFREE和PCTUSED存储参数,以及考虑数据库优化器和并行查询。具体方法包括明智地使用索引,避免可能导致索引...

    Oracle数据库DBA罗列所需要掌握知识点

    - PCTFREE和PCTUSED参数总和不能超过100%,这些参数用于控制行的存储方式,从而优化插入和更新操作的性能。 7. **回滚段(Rollback Segment):** - 单个事务不能跨越多个回滚段。 - 回滚段用于存储未提交事务的...

    Oracle调优心得

    例如,`PCTUSED`、`PCTFREE`、`INITRANS`和`MAXTRANS`等参数的合理设置可以避免不必要的空间浪费,提高数据访问效率。 - **空间管理**:使用自动段空间管理(ASSM)可以更好地管理空间分配,减少碎片化,从而提高...

    oracle dba 笔试题

    `PCTUSED`和`PCTFREE`参数用于控制数据块何时从自由列表中移入或移出。`PCTUSED`定义了数据块达到多少使用率时,才被重新加入自由列表,而`PCTFREE`则指定了数据块在使用率达到多少时,将从自由列表中移除。 2. **...

    Oracle与SQLserver的区别.docx

    Oracle 使用 pctfree 和 pctused 参数来管理存储空间,以降低数据行连接和迁移的风险,并且可以动态分配区和表空间。SQL Server 则以页为最小分配单位,每个页大小固定为 8KB,并通过扩展来管理空间。 存储结构方面...

    Oracle基础知识第八讲.pptx

    MSSM使用PCTFREE、PCTUSED和FREELIST等参数手动管理空间,而ASSM则通过位图跟踪空闲空间,简化管理,但不适用于包含大对象(LOB)的表空间。 在存储子句的优先级方面,段级别的存储参数优先于表空间级别的设置,...

    java总复习.pdf

    5. PCTFREE和PCTUSED参数: - **PCTFREE**:设置数据块更新预留的空间,当空间不足时,Oracle会从空闲列表中移除该块。 - **PCTUSED**:设定何时将数据块放回空闲列表,当使用空间低于此值时。 6. Oracle管理工具...

    认证试题oracle DBA

    8. **数据块空间管理**:参数 PCTUSED 和 PCTFREE 可以管理数据块中的空闲空间使用。 9. **实例组成**:Oracle 实例包含 ORACLE 进程和内存结构,不包含 I/O 结构,因为 I/O 结构是硬件层面的。 10. **调度进程...

    oracle数据库管理手册

    - **理解 PCTFREE 与 PCTUSED**: 这两个参数控制了数据块中的空间使用。 **7.3 管理表存储区(数据段)** - **创建表**: 使用CREATE TABLE语句创建。 - **STORAGE 子句**: 用于指定表的存储特性。 **7.4 管理表...

    ORACLE9i_优化设计与系统调整

    - **物理存储结构**:理解段、区和块的概念,根据工作负载选择合适的存储参数,如PCTFREE和PCTUSED,以及控制块大小。 - **索引策略**:创建和管理索引以加速查询,理解B树索引、位图索引和函数索引的适用场景。 ...

    Oracle与SqlServer区别.docx

    - Oracle 使用块作为存储单位,并且有 pctfree 和 pctused 参数来控制块的使用。表可以通过区(extent)进行动态分配,以减少空间分配的开销。表还可以分区,改善磁盘争用。 - SQL Server 以页为最小分配单位,8KB...

    oracle新手入门指导之一——数据库表空间知识.txt

    总之,在Oracle数据库管理中,正确理解和合理配置表空间及其相关参数对于保证数据库性能至关重要。通过了解表空间的组成部分和扩展机制,以及合理设置存储参数,可以有效地管理数据库存储资源,提高系统的整体性能。

    阿里巴巴校园招聘Oracle_DBA笔试题及参考答案.doc

    pctused 和 pctfree 是Oracle数据库中用于控制数据块空间管理的两个重要参数。pctused 设定了一个阈值,当数据块中的自由空间小于这个百分比时,该数据块将从自由链表(freelist)中移除。而pctfree则规定了数据块...

Global site tag (gtag.js) - Google Analytics