对Oracle 数据库的竞争调整

数据库 Oracle
以下饿文章主要是描述如何调整 Oracle 数据库的竞争,对于初学者在其相关的方面都有一些误解,以下的文章主要就是对其进行正确的分析。

本文主要讲述的是如何调整 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% 的空间用作行扩展。 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 消耗更少的资源。

 文章出自:http://database.csdn.net/page/96f66c75-55bb-42a7-9bdf-e402705c85e5

【编辑推荐】

  1. 探讨Oracle中rownum的用法
  2. Oracle细粒度的访问控制的基本工作方式
  3. 浅析:Oracle jdbc分页效率的测试
  4. Oracle数据库的异构服务原理描述
  5. Oracle移植到mysql中应注意的事项
责任编辑:佚名 来源: csdn
相关推荐

2009-11-02 18:56:49

调整Oracle数据库

2010-04-13 10:32:40

Oracle数据库编程

2010-04-12 17:19:16

Oracle数据库

2010-04-14 13:14:46

Oracle数据库

2010-04-21 09:49:10

Oracle数据库字符

2009-06-30 15:02:41

磁盘排序Oracle数据库性能

2010-04-01 17:06:57

Oracle数据库

2011-11-03 16:57:42

NoSQL

2010-04-19 13:25:45

Oracle调整

2009-02-01 13:33:13

Oracle数据库配置

2011-08-10 15:38:12

ConstraintOracle

2010-05-04 11:02:44

Oracle数据库

2011-03-17 14:51:33

数据库自我调整

2010-06-01 09:22:35

MySQL数据库

2010-04-14 15:58:17

Oracle程序开发

2017-09-22 11:01:00

Oracle数据库中直方图

2010-04-29 11:26:52

2010-04-22 15:53:06

Oracle数据库

2010-04-22 16:16:35

Oracle数据库

2011-03-10 13:24:26

点赞
收藏

51CTO技术栈公众号