- 浏览: 1023211 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (529)
- 服务器 (8)
- jsp (1)
- java (6)
- AIX (1)
- solaris (3)
- linux学习 (53)
- javaScript (2)
- hibernate (1)
- 数据库 (74)
- sql语句 (8)
- oracle 学习 (75)
- oracle 案例 (42)
- oracle 管理 (42)
- Oracle RAC (27)
- oracle data guard (12)
- oracle 参数讲解 (14)
- Oracle 字符集 (8)
- oracle性能调优 (24)
- oracle备份与恢复 (12)
- oracle Tablespace (9)
- oracle性能诊断艺术 (1)
- oracle 11g学习 (5)
- oracle streams (1)
- oracle upgrade and downgrade (4)
- db2学习 (13)
- db2命令学习 (2)
- mysql (28)
- sql server (30)
- sql server 2008 (0)
- 工具 (10)
- 操作系统 (3)
- c++ (1)
- stock (1)
- 生活 (5)
- HADOOP (2)
最新评论
-
massjcy:
...
如何将ubuntu文件夹中文名改为英文 -
skypiea:
谢谢。。。
终于解决了。。。
Oracle 10.2.0.4(5)EM不能启动的解决方案(Patch 8350262) -
qwe_rt:
引用vi /etc/sysconfig/network 请问 ...
Linux操作系统下配置静态IP上网 -
liuqiang:
sudo killall -9 apache2
ps 和 kill 命令详解 -
dazuiba:
引用*绝杀 kill -9 PID 当使用此命令时,一定要通过 ...
ps 和 kill 命令详解
目前,Oracle已经广泛的应用于各个行业。作为一名DBA,及时发现并整理碎片已经成为DBA日常工作中的一项重要维护内容。
1、碎片是如何产生的
当生成一个数据库时,它会分成称为表空间(tablespace)的多个逻辑段(segment),如系统(system)表空间,临时(temporary)表空间等。一个表空间可以包含多个数据范围(extent)和一个或多个自由范围块,即自由空间(free space)。
表空间、段、范围、自由空间的逻辑关系如下:
当表空间中生成一个段时,将从表空间有效自由空间中为这个段的初始范围分配空间。在这些初始范围充满数据时,段会请求增加另一个范围。这样的扩展过程会一直继续下去,直到达到最大的范围值,或者在表空间中已经没有自由空间用于下一个范围。最理想的状态就是一个段的数据可被存在单一的一个范围中。这样,所有的数据存储时靠近段内其它数据,并且寻找数据可少用一些指针。但是一个段包含多个范围的情况是大量存在的,没有任何措施可以保证这些范围是相邻存储的,如图〈1〉。当要满足一个空间要求时,数据库不再合并相邻的自由范围(除非别无选择), 而是寻找表空间中最大的自由范围来使用。这样将逐渐形成越来越多的离散的、分隔的、较小的自由空间,即碎片。
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 enterprise linux 6.0 安装oracle 11g 所需要的包安装
2012-07-22 08:02 7700Linux 版本是Oracle enterprise ... -
Oracle10gR2 中 Oracle Wallet 的初步使用和维护
2011-06-02 01:59 19961) Wallet作用 从Oracle10gR2开始, 通过 ... -
如何手工删除oracle数据库和软件
2011-06-02 00:29 1465一、手工删库和数据库文件有时候,有可能在dbca图形界面中找不 ... -
AIX下设置Oracle10g随机启动,随机关闭的步骤
2011-06-02 00:19 1456假如ORACLE_HOME为/opt/app/oracle/p ... -
数据库突然无法登陆,只有sysdba可以
2011-05-20 18:05 1650数据库突然无法登陆,只有sysdba可以登陆。 检查aler ... -
Linux安装Oracle报Checking operating system version must be redhat-3, SuSE-9, redhat
2011-03-24 01:26 1926在Linux系统中安装oralce的过程中,如果Linux发行 ... -
How To Update NLS_SORT Parameter Value When Using 10g Thin JDBC Driver ? [ID 469
2010-12-17 10:05 2974Applies to: JDBC - Version: 1 ... -
使用SQL_TRACE进行数据库诊断(转自eygle)
2010-12-16 17:30 865SQL_TRACE是Oracle提供的用 ... -
oracle 查询时忽略大小写的方案研究
2010-12-15 02:00 2491项目已经开发完毕,由于业务变动,某些查询需要忽略大小写,研究是 ... -
Read By Other Session
2010-12-02 22:52 760Read By Other Session Definiti ... -
Wait Event: cache buffers chains
2010-11-30 15:58 1168cache buffers chains是相对比较常见的冲突事 ... -
log file sync(日志文件同步) 与 Log file parallel write 等待事件
2010-11-28 20:47 2152log file sync(日志文件同步)等待事件具有一个参数 ... -
删除Linux非rac环境下的ASM实例
2010-04-25 01:48 2025环境说明: 操作系统:CentOS 5 x86数据库:O ... -
扩大oracle最大session数以及清除inactive会话
2010-04-12 16:00 7337从上周起,服务器Oracle数据库出现问题,用不到半天,就会报 ... -
设计数据库时需要考虑的问题
2010-03-04 17:34 1544成功的管理系统=50% 的业务+(25%的数据库+25%的程序 ... -
介绍Oracle数据库锁的种类及研究
2009-12-02 09:30 1119本文通过对Oracle数据库锁机制的研究,首先介绍了Oracl ... -
expdp中使用连接字符串和network_link的区别
2009-12-01 11:47 1582expdp属于服务端工具,而exp属于客户端工具,expdp生 ... -
ora10G 使用数据泵(EXPDP和IMPDP)时应该注意的事项
2009-12-01 11:45 1250Oracle Database 10g引入了最新的数据泵(Da ... -
使用Oracle 10g数据泵(EXPDP/IMPDP)
2009-12-01 11:22 2031一、关于数据泵的概述 在Oracle 10 ... -
10g新特性之-expdp与传统exp的速度比较
2009-12-01 11:18 1311测试环境: System Configuration: Su ...
相关推荐
Oracle数据库碎片整理是数据库管理员(DBA)的一项基本维护内容。数据库碎片是影响数据库性能的一大因素,碎片的产生是由于表空间中的自由空间被分割成多个小的自由范围块,导致数据存储不连续、寻找数据困难,从而...
"Oracle数据库碎片如何整理" Oracle数据库碎片是指在数据库中由于表空间、段、范围、自由空间的逻辑关系导致的碎片问题,会对系统性能和表空间造成影响。这种碎片问题可以通过计算FSFI值来检测,高于30的FSFI值表示...
### Oracle数据库整理表碎片 #### 表碎片的来源与影响 在Oracle数据库中,随着对表数据的频繁增删改查操作,特别是大量的删除操作,会导致表产生所谓的“碎片”。这是因为,当执行删除操作后,虽然原数据所占用的...
【Oracle数据库碎片整理】 Oracle数据库在长期运行过程中,由于数据的增删改操作,往往会产生大量的碎片,这不仅会降低数据库的性能,还可能导致空间浪费。碎片主要分为两种类型:内部碎片(Internal Fragmentation...
Oracle数据库是业界广泛使用的大型关系型数据库系统,它以强大的功能、高性能和稳定性著称。文档《oracle数据库从入门到精通.pdf》详细地介绍了Oracle数据库的基础知识和高级操作,使得学习者能够从基础的表空间创建...
"浅谈Oracle数据库的碎片整理" 在 Oracle 数据库中,碎片整理是一个非常重要的维护内容。随着时间的推移,基于数据库的应用系统的广泛使用,产生的碎片会越来越多,对数据库性能产生严重的影响。 碎片的产生是由于...
本书由多位工作在数据库维护一线的工程师合著而成,包含了精心挑选的数据库诊断案例与性能优化实践经验,内容涉及oracle典型错误的分析和诊断,各种sql优化方法(包括调整索引,处理表碎片,优化分页查询,改善执行...
Oracle DBA 数据库日常维护完全手册 本文档为 Oracle 数据库管理员(DBA)提供了日常维护的完全手册,涵盖了数据库日常维护的重要知识点,包括 Oracle 警告日志文件监控、数据库表空间使用情况监控、查看数据库的...
Oracle数据库DBA专题技术是IT领域中一个至关重要的主题,尤其对于那些负责管理和维护Oracle数据库系统的数据库管理员(DBA)而言。盖国强,作为Oracle领域的知名专家,他的著作《Oracle数据库DBA专题技术精粹》是这...
### Oracle数据库日常维护手册知识点详解 #### 一、Oracle警告日志文件监控 **知识点概述:** ...通过这些监控手段和相应的处理措施,DBA能够有效管理和维护Oracle数据库,确保其稳定高效地运行。
### Oracle数据库DBA神器 #### Oracle数据库日常维护脚本大全汇总_DBA必备神器 在现代企业环境中,Oracle数据库因其稳定性、安全性和强大的功能而被广泛采用。为了更好地管理和维护Oracle数据库,DBA(数据库管理...
#### 二、Oracle数据库碎片化原理 在Oracle数据库中,数据存储在不同的逻辑结构中,包括表空间(Tablespace)、段(Segment)等。随着数据库的使用,这些存储区域会发生变化,导致存储空间分配不连续,即产生了所谓的...
而数据库碎片则是影响性能的一个重要因素,因此及时发现并处理碎片问题成为了DBA的一项基本维护工作。 当创建一个Oracle数据库时,它会被划分为多个逻辑段,称为表空间(Tablespace),包括但不限于系统(System)表...
Oracle数据库管理员(DBA)在维护数据库系统的稳定运行和性能方面扮演着至关重要的角色。随着数据量的不断增长和业务需求的日益复杂化,DBA面临越来越多的挑战。为了提升个人技能,对于一名合格的Oracle DBA来说,...
本书由多位工作在数据库维护一线的工程师合著而成,包含了精心挑选的数据库诊断案例与性能优化实践经验,内容涉及Oracle典型错误的分析和诊断,各种SQL优化方法(包括调整索引,处理表碎片,优化分页查询,改善执行...
知识点:DBA_FREE_SPACE 是 Oracle 数据库中的一个视图,用于判断 tablespace 的剩余空间。 23. 如何判断谁往表里增加了一条记录? 答案:auditing 知识点:auditing 是一种操作,用于记录谁往表里增加了一条记录。...
总之,Oracle数据库空间的使用和管理涉及多个层面,包括概念理解、规划、性能优化和碎片管理。通过深入理解这些概念并熟练掌握相关SQL语句和工具,可以有效地管理数据库空间,从而提高整体系统的性能和稳定性。
### Oracle数据库索引的维护 在Oracle数据库管理与优化的过程中,索引的维护是非常关键的一环。合理地创建、管理和优化索引能够显著提高查询性能,降低系统的响应时间,从而提升整个应用程序的效率。本文将从Oracle...
在Oracle数据库管理与优化的过程中,了解并处理表碎片是非常重要的一个环节。本文将详细介绍如何通过SQL查询来检测Oracle表的碎片情况,并对给出的SQL查询语句进行深入解析。 #### 一、Oracle表碎片概念 在Oracle...