Oracle 作为一种大型数据库,广泛应用于金融、邮电、电力、民航等数据吞吐量巨大,计算机网络广泛普及的重要部门。对于系统管理员来讲,如何保证网络稳定运行,如 何提高数据库性能,使其更加安全高效,就显得尤为重要。作为影响数据库性能的一大因素 -- 数据库碎片,应当引起 DBA 的足够重视,及时发现并整理碎片乃是 DBA 一项基本维护内容。
1、碎片是如何产生的
当生成一个数据库时,它会分成称为表空间( Tablespace )的多个逻辑段( Segment ),如系统(System)表空间 , 临时(Temporary)表空间等。一个表空间可以包含多个数据范围(Extent)和一个或多个自由范围块,即自由空间(Free Space)。
表空间、段、范围、自由空间的逻辑关系如下:
当表空间中生成一个段时,将从表空间有效自由空间中为这个段的初始范围分配空间。在这些初始范围充满数据时,段会请求增加另一个范围。这样的扩 展过程会一直继续下去,直到达到最大的范围值,或者在表空间中已经没有自由空间用于下一个范围。最理想的状态就是一个段的数据可被存在单一的一个范围中。 这样,所有的数据存储时靠近段内其它数据,并且寻找数据可少用一些指针。但是一个段包含多个范围的情况是大量存在的,没有任何措施可以保证这些范围是相邻 存储的,当要满足一个空间要求时,数据库不再合并相邻的自由范围(除非别无选择), 而是寻找表空间中最大的自由范围来使用。这样将逐渐形成越来越多的离散的、分隔的、较小的自由空间,即碎片。例如:
2、碎片对系统的影响
随着时间推移,基于数据库的应用系统的广泛使用,产生的碎片会越来越多,将对数据库有以下两点主要影响:
1)导致系统性能减弱。
如上所述,当要满足一个空间要求时,数据库将首先查找当前最大的自由范围,而 “最大”自由范围逐渐变小,要找到一个足够大的自由范围已变得越来越困难,从而导致表空间中的速度障碍,使数据库的空间分配愈发远离理想状态;
2)浪费大量的表空间。
尽管有一部分自由范围(如表空间的 pctincrease 为非 0 )将会被 SMON (系统监控)后台进程周期性地合并,但始终有一部分自由范围无法得以自动合并,浪费了大量的表空间。
3、自由范围的碎片计算
由于自由空间碎片是由几部分组成,如范围数量、最大范围尺寸等,我们可用 FSFI--Free Space Fragmentation Index (自由空间碎片索引)值来直观体现:
FSFI=100*SQRT(max(extent)/sum(extents))*1/SQRT(SQRT(count(extents))) |
可以看出, FSFI 的最大可能值为 100 (一个理想的单文件表空间)。随着范围的增加, FSFI 值缓慢下降,而随着最大范围尺寸的减少, FSFI 值会迅速下降。
下面的脚本可以用来计算 FSFI 值:
rem FSFI Value Compute
rem fsfi.sql
column FSFI format 999,99
select tablespace_name,sqrt(max(blocks)/sum(blocks))*
(100/sqrt(sqrt(count(blocks)))) FSFI
from dba_free_space
group by tablespace_name order by 1;
spool fsfi.rep;
/
spool off; |
比如,在某数据库运行脚本 fsfi.sql, 得到以下 FSFI 值:
TABLESPACE_NAME FSFI
-------------------------------------
RBS 74.06
SYSTEM 100.00
TEMP 22.82
TOOLS 75.79
USERS 100.00
USER_TOOLS 100.00
YDCX_DATA 47.34
YDCX_IDX 57.19
YDJF_DATA 33.80
YDJF_IDX 75.55 |
统计出了数据库的 FSFI 值,就可以把它作为一个可比参数。在一个有着足够有效自由空间,且FSFI 值超过 30 的表空间中,很少会遇见有效自由空间的问题。当一个空间将要接近可比参数时,就需要做碎片整理了。
4、自由范围的碎片整理
1)表空间的 pctincrease 值为非 0。
可以将表空间的缺省存储参数 pctincrease 改为非 0 。一般将其设为 1 ,如:
alter tablespace temp
default storage(pctincrease 1); |
这样 SMON 便会将自由范围自动合并。也可以手工合并自由范围: alter tablespace temp coalesce。
5、段的碎片整理
我们知道,段由范围组成。在有些情况下,有必要对段的碎片进行整理。要查看段的有关信息,可查看数据字典 dba_segments ,范围的信息可查看数据字典 dba_extents 。如果段的碎片过多, 将其数据压缩到一个范围的最简单方法便是用正确的存储参数将这个段重建,然后将旧表中的数据插入到新表,同时删除旧表。这个过程可以用 Import/Export (输入 / 输出)工具来完成。
Export ()命令有一个(压缩)标志,这个标志在读表时会引发 Export 确定该表所分配的物理空间量,它会向输出转储文件写入一个新的初始化存储参数 -- 等于全部所分配空间。若这个表关闭, 则使用 Import ()工具重新生成。这样,它的数据会放入一个新的、较大的初始段中。例如:
exp user/password file=exp.dmp compress=Y grants=Y indexes=Y
tables=(table1,table2); |
若输出成功,则从库中删除已输出的表,然后从输出转储文件中输入表:
imp user/password file=exp.dmp commit=Y buffer=64000 full=Y |
这种方法可用于整个数据库。
以上简单分析了 Oracle 数据库碎片的产生、计算方法及整理,仅供参考。数据库的性能优化是一项技术含量高,同时又需要有足够耐心、认真细致的工作。 对数据库碎片的一点探讨,
下面是一种如何自动处理表空间碎片的代码,希望对上大家看上文有用
Coalesce Tablespace Automatically
This technique comes from Sandeep
Naik, a database administrator
for GSXXI, Inc. in New York City, New York
Here is a handy script which can be
scheduled to automatically run
and coalesces the tablespaces.
This script is designed to run in NT
but can be run in any operating system
by slight modifications in the path where the file spools
from the SQLPLUS environment.
It assumes that the user who runs the script
has priviledges to view the data dictionary.
Start of code
--------------------------------------
sqlplus /
prompt this script will coalesce the
tablespace automatically
set verify off;
set termout off;
set head off;
spool c: empcoalesce.log
select alter tablespace
||TABLESPACE_NAME|| coalesce ;
from DBA_FREE_SPACE_COALESCED where
PERCENT_EXTENTS_COALESCED <100
or PERCENT_BLOCKS_COALESCED<100 ;
spool off;
@ c: empcoalesce.log
set head on;
set termout on;
set verify on;
prompt Tablespaces are coalesced successfully
分享到:
相关推荐
Oracle数据库碎片整理.pdf
Oracle数据库在长期运行过程中,尤其是面对大量的插入、更新和删除操作时,物理存储介质上会产生大量碎片,这将影响数据库的性能和应用程序的运行速度。本文主要探讨了Oracle数据库中的三种碎片类型:表空间碎片、表...
"Oracle数据库碎片如何整理" Oracle数据库碎片是指在数据库中由于表空间、段、范围、自由空间的逻辑关系导致的碎片问题,会对系统性能和表空间造成影响。这种碎片问题可以通过计算FSFI值来检测,高于30的FSFI值表示...
### Oracle数据库整理表碎片 #### 表碎片的来源与影响 在Oracle数据库中,随着对表数据的频繁增删改查操作,特别是大量的删除操作,会导致表产生所谓的“碎片”。这是因为,当执行删除操作后,虽然原数据所占用的...
9. Oracle数据库碎片整理 10.ORACLE性能调整1 11.ORACLE性能调整2 12.Oracle专家调优秘密 13.PL_SQL单行函数和组函数详解 14.PL-SQL 15.PLSQL异常处理初步 16.SQL语句性能调整原则 17.创建和使用...
"浅谈Oracle数据库的碎片整理" 在 Oracle 数据库中,碎片整理是一个非常重要的维护内容。随着时间的推移,基于数据库的应用系统的广泛使用,产生的碎片会越来越多,对数据库性能产生严重的影响。 碎片的产生是由于...
### Oracle 数据库碎片整理 #### 碎片的产生过程及其原因 在Oracle数据库中,随着数据的增删改查等操作,存储空间中的数据块(Blocks)可能会变得分散不连续,这种现象被称为碎片化(Fragmentation)。碎片化的...
### Oracle空间碎片整理 在Oracle数据库管理中,随着数据的增删改查操作频繁进行,数据库表空间中可能会出现大量的自由空间碎片(Free Space Fragmentation, FSF)。这些碎片不仅会降低查询性能,还可能影响到...
#### 二、Oracle数据库碎片化原理 在Oracle数据库中,数据存储在不同的逻辑结构中,包括表空间(Tablespace)、段(Segment)等。随着数据库的使用,这些存储区域会发生变化,导致存储空间分配不连续,即产生了所谓的...
Oracle数据库在长期运行过程中,由于数据的增删改操作,会导致数据存储不连续,形成所谓的“碎片”。碎片整理是数据库维护的重要环节,旨在优化数据库性能和提高空间利用率。 1. 碎片的产生 Oracle数据库中,表空间...
数据库碎片整理及优化策略ORACLE.pdf
### ORACLE 碎片整理 #### 一、碎片产生的原因与机制 Oracle数据库作为一种广泛应用于高数据吞吐量行业的大型数据库系统,在金融、电信、电力、航空等多个关键领域发挥着重要作用。对于数据库管理员(DBA)而言,...
其次,Oracle数据库碎片整理是维护数据库健康状态的重要环节。数据库碎片主要分为表碎片和索引碎片。表碎片可能导致空间利用率下降,影响查询性能;索引碎片则会降低索引的查找效率。通过使用DBMS_REDEFINITION、...
Oracle数据库性能优化(碎片整理).doc
4. **Oracle 数据库碎片整理**: 数据库碎片可能导致空间利用率降低,查询性能下降。文件可能讲解了如何识别和处理各种类型的碎片,如表空间碎片、段碎片和行碎片。常见的碎片整理方法包括ALTER TABLE ... MOVE、DBMS...