Chinaunix首页 | 论坛 | 博客
  • 博客访问: 50330
  • 博文数量: 25
  • 博客积分: 2015
  • 博客等级: 大尉
  • 技术积分: 215
  • 用 户 组: 普通用户
  • 注册时间: 2007-12-16 17:34
文章分类
文章存档

2008年(25)

我的朋友

分类: Oracle

2008-06-16 18:10:06

Oracle 回滚段管理

1、ora-01555错误的是怎么产生的?有什么办法解决?2、回滚段(回滚表空间)有什么作用?3、数据库启动的时候,如何加载回滚段(回滚段表空间)。4、回滚段的数量由什么公式来计算5、回滚表空间的大小如何确定?
什么是undo
管理undo tablespace
管理 rollback segment

目 录
什么是undo
管理undo tablespace
管理 rollback segment
什么是undo?
oracle数据库在回退、撤销或者改变数据所需要的维护数据库信息的一种手段。这里的数据库信息是指在数据库提交之前的记录的改变等事务信息。
Undo 信息主要有以下用途:
当系统发出rollback信息
数据库恢复
提供读一致性
当系统发出rollback命令时,undo 信息通过记录的信息将数据库的改变恢复到commit之前的状态。在数据库恢复期间,undo信息被用来从redo log中撤销任何未提交到数据文件的事务。当一个用户在访问数据时,Undo记录通过维护访问数据的前镜像数据来保证当有其他用户改变相同数据时数据库的读一致性。
以前数据库使用回滚段来存储undo信息,这种回滚段管理方式非常的复杂。现在数据库采用undo的方式降低了管理的复杂性,同时减少了dba的工作负荷。但是在数据库只能使用这两种方式的一种。可以在数据库里定义两种方式的文件,但是,同一时刻,必须指定数据使用哪一种方式。当你需要在两种方式中切换时,必须将系统重新启动。
Oracle数据库一直使用系统回滚段来完成系统的事务。系统回滚段是在数据库,创建的时候产生的,系统启动后就一直在线。Dba不需要对它作任何的操作来优化。

指定undo的方式
在oracle9i中有一个初始化参数:undo_management。当将undo_management设置成AUTO时系统使用重做表空间来管理回滚段,当它被设置成MENUAL时系统使用回滚段。
在oracle9i中推荐使用重做表空间代替回滚段。
当系统使用auto方式管理undo信息时,系统必须指定一个undo表空间。这个表空间可以是在数据库创建时产生,也可以数据库创建后再创建。
当实例启动的时候,系统自动选择第一个有效的undo表空间或者是rollback segment,如果没有有效的可用的undo表空间或者是回滚段,系统使用system rollback segment。这种情况是不被推荐的,当系统运行在没有undo的情况下,系统会在alert.log中记录一条警告信息。
9i自动管理模式
如果系统使用要使用auto方式管理undo信息,那么需要通过指定初始化参数undo_tablespace的值来指定系统使用哪一个undo表空间来存放undo信息。如果
指定了undo_tablespace的值,但是系统中不存在这样的表空间,那些系统启动将会失败。此时可以做的操作是,如果系统存在undo表空间,为undo_tablespace指定正确的undo表空间名字,或者将undo_tablespace注释。系统会采用存在的undo表空间。否则使用手动方式。
相关的初始化参数:
undo_tablespace 指名系统使用哪一个重做表空间。
undo_suppress_errors 被设置成true时表示系统创建和使用回滚段时忽略错误。
undo_retention 系统提交后,回滚段的数据保留多长时间,单位是秒。
当系统被设置成menual后,这几个参数被忽略。
manual管理模式
当将系统中初始化参数undo_management设置成manual后,系统启动后使用rollback segment方式存储undo信息。如果系统没有指定undo_management,那么系统默认以manual方式启动,即使设置了auto方式的参数,这些参数将被忽略。
当实例启动时,系统根据如下几个步骤确认online的rollback segment的数量:
初始化参数rollback_segments
初始化参数transactions、transactions_per_rollback_segment
与menual相关的初始化参数
rollback_segments 指定实例启动时所需要的回滚段
transactions 指定系统中最大的并发事务数
transactions_per_rollback_segment 指定每一个回滚段支持的并发数
max_rollback_segments 指明系统支持的最大的online的回滚段数目
管理undo tablespace
创建undo tablespace
创建undo talespace有两种方式:
? 一是数据库创建时创建undo tablespace;
? 第二种就是在一个已经存在的数据库创建。
在undo tablespace中不能创建数据库对象,这是因为这个表空间是为数据库recover而准备的。
创建数据库时创建undo tablespace
在创建数据库的时候可以通过指定undo子句来创建undo tablespace,但是这个子句不是必须的。
如果在创建数据库时,系统指定是auto模式,但是没有指明undo tablespace的名字,那么系统会创建一个默认的回滚表空间,名称叫sys_undotbs。这个表空间根据oracle定义的缺省值创建。初始化大小是10m,可以自动扩展。不过oracle推荐最好还是使用一个指定的大小。
CREATE DATABASE rbdb1
CONTROLFILE REUSE
.
.
UNDO TABLESPACE undotbs_01 DATAFILE '/u01/oracle/rbdb1/undo0101.dbf';
注意:如果此时系统创建undo失败,那么整个创建数据库的命令就失败了。此时
Dba需要删除已经创建的数据文件,纠正错误,重建创建数据库。
使用create undo tablespace子句创建
CREATE UNDO TABLESPACE undotbs_02
DATAFILE '/u01/oracle/rbdb1/undo0201.dbf' SIZE 2M REUSE
AUTOEXTEND ON;
使用alter undo tablespace子句修改undo tablespace
Undo tablespace的修改包含以下几种:
增加数据文件
重命名数据文件
使数据文件online或者offline
开始或者结束一个联机备份
ALTER TABLESPACE undotbs_01
ADD DATAFILE '/u01/oracle/rbdb1/undo0102.dbf' AUTOEXTEND ON NEXT 1M MAXSIZE UNLIMITED;

ALTER TABLESPACE undotbs_01 RENAME DATAFILE '/u01/oracle/rbdb1/undo0102.dbf' TO '/u01/oracle/rbdb1/undo0101.dbf';
ALTER TABLESPACE undotbs_01 online|offline;
ALTER TABLESPACE undotbs_01BEGIN|END BACKUP;

使用drop undo tablespace子句删除undo tablespace
Drop tablespace undotbs_01;Drop undo表空间的时候必须是在未使用的情况下才能进行。如果undo表空间正
在使用(例如事务失败,但是还没有恢复成功),那么drop表空间命令将失败。在drop表空间的时候可以使用including contents。
切换undo tablespace
切换undo表空间有两种方式:一种是使用命令动态修改;一种是修改初始化参数后重新启动数据库。Alter system set undo_tablespace=undotbs1;然后undo表空间就会切换到undotbs1,以下几种情况会导致切换命令失败:表空间不存在;
表空间不是一个回滚段表空间;
表空间已经被另一个实例使用。
当切换命令完成后,所有的事务就会在新的回滚表空间内进行。
切换的操作不等待旧undo表空间的事务提交。如果旧undo表空间有事务未提交,
那么旧的undo表空间进入pending offline状态,在这种模式下所有的事务能够继
续进行,但是undo表空间不能被其他实例使用,也不能被删除,直到所有的事务
提交后, undo表空间才进入offline模式。

设置undo_retention
dba可以设置undo_retention初始化参数指定undo回滚表空间保留undo信息的时间。在设置好这个参数时,系统会保留undo信息在指定的时间断后才收回这个空间。
一般情况下,系统会保留undo信息到指定的时间后才回收空间,但是,如果系统
存在大量的事务,也会将未到期的undo空间回收,以供使用。
Undo 表空间大小的设计规范的计算公式
Undospace = UR * UPS *db_block_size+ 冗余量
UR: 表示在undo中保持的最长时间数(秒),由数据库参数UNDO_RETENTION
值决定。
UPS:表示在undo中,每秒产生的数据库块数量。
和undo有关的动态性能视图v$undostat 包含undo的统计信息。使用这张视图可以估计系统当前所需的undo大小。
v$rollstat 是undo模式的视图。是undo表空间的undo segments的统计信息
v$transaction 包含undo segments的信息。
dba_undo_extents 包含undo表空间中每一个范围的提交时间。
管理回滚段
回滚段的使用方针
使用多个回滚段
使用多个回滚段来分担回滚段的争用,以提高系统性能。系统采用循环的方式来分配回滚段。当oracle创建数据库时候,系统自动在system中分配一个system rollback segment,用来完成系统的事务,不为大家共用。所以系统最后能有至少一个回滚段存放用户回滚信息。
系统能够加载的用户回滚段数量和以下几个初始化参数有关:
transactions_per_rollback_segment,指定每一个回滚段支持的并发数;
max_rollback_segments,指明系统支持的最大的online的回滚段数目;
rollback_segments,指定实例启动时所需要的回滚段;
选择好回滚段的类型
private必须通过实例指定名称后才能使用。
如:必须在初始化参数中rollback_segments指定后,实例启动才能使用,或者在实例启动后online才能使用。
public则是实例启动时系统自动发现,系统根据初始化参数决定系统启动时的回滚段。
为事务指定回滚段
在系统启动时指定所需要的回滚段
估计回滚段的大小
回滚段大小应该基于系统最大的事务。如果回滚段过小,容易产生ora-01555错误。可以使用optimize选项来限制回滚段自动回收。回滚段的大小应该是最大表的大小的10%,这个可以指定maxextents的数量。
创建范围大小和数量相等的回滚段组
一般来说一个回滚段应该包含10到20个范围。
s=T/n
s是初始化时定义的范围的大小,T是初始化的回滚段大小,n是范围数。由此可以确定定义回滚段的子句的各个参数。

回滚段的使用方针
定义optimal的值
设置这个参数可以避免回滚段无限扩展以及系统自动回收空间。最小是两个范围的大小。
设置回滚段在不同的表空间
1:如果系统只有一个回滚表空间,那么回滚段出现问题,影响系统不能运行。
2:包含回滚段的表空间经常分配和去配容易产生碎片。
3:当回滚表空间被离线时,系统将没有回滚表空间可以用。
MINEXTENTS最小等于2
OPTIMAL最小应该设置成两个extents大小
INITIAL和 NEXT最好一样,除了应用使用指定的回滚段;

创建回滚段
当创建回滚段时,系统必须要有CREATE ROLLBACK SEGMENT系统权限。CREATE ROLLBACK SEGMENT RB01 TABLESPACE RBS1
STORAGE (INITIAL integer K|M NEXT integer K|M MINEXTENTS integer MAXEXTENTS integer OPTIMAL integer K|M );

他的作用如下:
创建的回滚段会online;
指定了存储参数;

修改回滚段当修改回滚段时,系统必须要有ALTER ROLLBACK SEGMENT系统权限。
ALTER ROLLBACK SEGMENT RB01 ONLINE;
ALTER ROLLBACK SEGMENT RB01 STORAGE ( MAXEXTENTS 200 OPTIMAL 2048K );
ALTER ROLLBACK SEGMENT RB01 SHRINK;
(有OPTIMAL参数时, 缩小到OPTIMAL值; 没有OPTIMAL参数时, 缩小到MINEXTENTS所对应的尺寸) ALTER ROLLBACK SEGMENT RB01 SHRINK TO 2048K;
ALTER ROLLBACK SEGMENT RB01 STAROGE(MAXEXTENTS 120);
他的作用如下:
使回滚段online或者offline;
修改存储参数;
收缩回滚段;

删除回滚段
当删除回滚段时,系统必须要有DROP ROLLBACK SEGMENT系统权限。
原则上,INITIAL总应该等于NEXT,除了使用SET TRANSACTION USE ROLLBACK SEGMENT XXX的回滚段。由于INITIAL不能直接修改,只能先drop然后创建。
DROP ROLLBACK SEGMENT RB01;
CREATE ROLLBACK SEGMENT RB01 TABLESPACE RBS1
STORAGE ( INITIAL 100K NEXT 100K MINEXTENTS 20 MAXEXTENTS 121 OPTIMAL 2000K);
在事务中使用特定的回滚段 SET TRANSACTION USE ROLLBACK SEGMENT RB_LARGE1;
通过这个命令,可以:
根据事务量的大小,决定使用哪一个回滚段;
将大的查询的事务放入单独的回滚段;
当存在大的查询使用事务时,可以将它放入大的回滚段。
和回滚段相关的性能视图
DBA_ROLLBACK_GEGS 描述回滚段的信息,包含回滚段的名字和表空间;
DBA_SEGMENTS 描述回滚段的附加信息;
V$ROLLNAME 列出在线回滚段的名称
V$ROLLSTAT 包含回滚段的统计信息
V$TRANSACTION 包含撤销的统计信息

阅读(869) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~