`
JamesQian
  • 浏览: 55691 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

oracle block的PCTUSED,PCTFREE,freelist等(自己理解总结)

阅读更多

     PCTUSED参数:当block 实际数据(block头信息和datas数据)占有的空间低于设定值时,将会被加到freelist中。譬如 PCTUSED=40.但删除数据后,剩余空间大于(1-40% )时,将会把此block移到freeList中。
    
PCTFREE参数:使用block时候,当有效数据的空间大于设定值,将不允许被插入新的行(每个block当然可以存放多行)。这样的block只允许被用来update增加新的字段行等操作。

    如果 PCTUSED设置过高,这样无疑能提高block空间的利用率。但是缺点是增加少量行就会撑满block(即需要重新申请freelist中的block),需要频繁的请求IO(非固态硬盘)

      如果ptcFree设置的值过高,会导致更新数据时候block爆满的情况,会发生行迁移(本行生成一个指向关联行的指针)。导致访问的效率低下。

      oracle create table时可以设置 PCTUSED PCTUSED这两个参数。需要根据业务需求做实际的调整!考虑的因素:一行数据的平均的大小,是否会频繁更新数据(插入数据)等因素。

 

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

 

参考信息:

pctused:一个块的使用水位的百分比,这个水位将使该块返回到可用列表中去等待更多的插入操作。
  pctfree:用来为一个块保留的空间百分比,以防止在今后的更新操作中增加一列或多列值的长度。
  freelist:可用列表是表中的一组可插入数据的可用块。
  行连接:指一行存储在多个块中的情况,这是因为该行的长度超过了一个块的可用空间大小,即行链接是跨越多块的行。
  行迁移:指一个数据行不适合放入当前块而被重新定位到另一个块(那里有充足的空间)中,但在原始块中保留一个指针的情形。原始块中的指针是必需的,因为索引的ROWID项仍然指向原始位置。

  计算公式:

  PCTFREE=(Average Row Size-Initial Row Size)*100/Average Row Size
  PCTUSED=(100-PCTFREE) -Average Row Size * 100/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 un-links的(即将块由freelists中移除)。设置pctfree=10 意味着每个块都保留10%的空间用作行扩展。pctused参数是控制freelist re-links的。设置pctused=40意味着只有在块的使用低于40%时才会回到表格的freelists中。

  许多新手对于一个块重新回到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实例的数目。

分享到:
评论

相关推荐

    Oracle基础知识第八讲.pptx

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

    Oracle基础知识PPT学习教案.pptx

    MSSM允许用户通过PCTFREE、PCTUSED和FREELIST参数精细控制空间使用,而ASSM使用位图来跟踪可用空间,简化了空间管理,但只支持PCTFREE参数,并且不适用于包含大对象(LOB)的表空间。 总的来说,理解Oracle数据库的...

    Oracle基础知识PPT课件.pptx

    MSSM允许通过参数如PCTFREE、PCTUSED和FREELIST来精细控制数据块的使用。ASSM使用位图来跟踪段的可用空间,简化了空间管理,但不适用于包含大对象(LOB)的表空间。 总的来说,理解Oracle的这些基本概念和管理机制...

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

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

    Oracle 45 道面试题及答案.docx

    PCTUSED 和 PCTFREE 控制数据块是否出现在 freelist 中,PCTFREE 控制数据块中保留用于 update 的空间。 Table/Segment/Extent/Block 之间的关系 Table 创建时,默认创建了一个数据段,每个数据段含有 min extents...

    oracle面试题

    - `pctused` 和 `pctfree` 是Oracle数据库中控制数据块空间利用率的两个参数。`pctused` 设定的是当数据块的自由空间使用达到多少百分比时,该数据块将从空闲链表(freelist)中移除。而`pctfree`则规定了数据块中...

    oracle dba 笔试题

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

    ORACLE DBA面试题(按不同类型分类)

    1. PCTUSED 和 PCTFREE 的含义和作用:PCTUSED 表示数据块什么时候移入和移出 FREELIST,PCTFREE 表示数据块什么时候从 FREELIST 中移出。 2. TABLE / SEGMENT / EXTENT / BLOCK 之间的关系:一个 TABLE 至少是一个 ...

    Oracle基础知识_第八讲.pptx

    为了更有效地管理段内的空间,Oracle允许数据库管理员通过设置PCTFREE和PCTUSED两个参数来控制数据块的使用情况。PCTFREE参数定义了数据块中保留给更新操作的空间百分比,而PCTUSED参数指定了数据块至少要空闲多少...

    DataInOracle-Storage.ppt

    MSSM需要手动管理空间,包括pctused、freelists和freelist groups等参数。ASSM自9i版本引入,10g后成为默认设置,它废弃了pctused,但保留了pctfree,并通过自动管理空闲空间来提高性能。 在Oracle中,数据块...

    oracle区管理和段空间管理详细介绍

    1. **手工段空间管理(Manual Segment Space Management,MSSM)**:在这个模式下,DBA需要设置参数如`FREELISTS`、`FREELIST GROUPS`、`PCTUSED`、`PCTFREE`和`INITRANS`来控制段空间的分配和使用。`FREELISTS`是一...

    存储结构与关联

    - 通过设置`PCTFREE`、`PCTUSED`和`FREELIST`等参数来进行配置。 #### 获得存储信息 为了监控和管理Oracle数据库的存储结构,可以查询以下几个视图: - `DBA_EXTENTS`:显示数据库中各段所占用的Extent信息。 - ...

    培训sql性能优化交流资料XXXX.pptx

    - **版本与参数设置**:选择适合的Oracle版本,并调整相关参数以适应系统需求,例如优化freelists和freelist组的配置,调整pctfree和pctused参数以控制表空间和索引的空间管理。 2. **方案层面**: - 分析SQL执行...

Global site tag (gtag.js) - Google Analytics