设为首页 加入收藏

TOP

bbed修改undo段状态(ORA-01578)(一)
2014-11-24 00:59:50 来源: 作者: 【 】 浏览:30
Tags:bbed 修改 undo 状态 ORA-01578
ZBDBA@orcl11g>select * from zbdba;
select * from zbdba
              *
ERROR at line 1:
ORA-01578: ORACLE data block corrupted (file # 3, block # 1449)
ORA-01110: data file 3: '/opt/oracle/oradata/orcl11g/undotbs01.dbf'

这里是事务正在执行,但是数据库直接以abort方式关机,并且对应的回滚段损坏

当然这里其实不需要bbed,只需要用_offline_rollback_segments 隐含参数标记对应的回滚段,然后使用drop rollback segment 该回滚段即可
这里使用bbed目的是在于研究undo回滚段的状态存于何处以及如何修改

这里我们创建另外一个undo表空间,并且切换到该表空间

ZBDBA@orcl11g>create undo tablespace undotbs02 datafile '/opt/oracle/oradata/orcl11g/undotb02.dbf' size 100m;

Tablespace created.

ZBDBA@orcl11g>alter system set undo_tablespace=undotbs02;

System altered.

ZBDBA@orcl11g>show parameter undo
NAME                                 TYPE                   VALUE
------------------------------------ ---------------------- ------------------------------
undo_management                      string                 AUTO
undo_retention                       integer                900
undo_tablespace                      string                 UNDOTBS02
我们查看回滚段的状态,发现即使切换了,还有一个回滚段处于online状态,因为这个回滚段上面还存在需要恢复的数据,但是这个回滚段已经被损坏,无法进行恢复。那么我们只能将其删除。
ZBDBA@orcl11g>select segment_name,tablespace_name,status from dba_rollback_segs;
SEGMENT_NAME                   TABLESPACE_NAME      STATUS
------------------------------ -------------------- ------------------------------------------------------------
SYSTEM                         SYSTEM               ONLINE
_SYSSMU10_3550978943$          UNDOTBS1             ONLINE
_SYSSMU9_1424341975$           UNDOTBS1             OFFLINE
_SYSSMU8_2012382730$           UNDOTBS1             OFFLINE
_SYSSMU7_3286610060$           UNDOTBS1             OFFLINE
_SYSSMU6_2443381498$           UNDOTBS1             OFFLINE
_SYSSMU5_1527469038$           UNDOTBS1             OFFLINE
_SYSSMU4_1152005954$           UNDOTBS1             OFFLINE
_SYSSMU3_2097677531$           UNDOTBS1             OFFLINE
_SYSSMU2_2232571081$           UNDOTBS1             OFFLINE
_SYSSMU1_3780397527$           UNDOTBS1             OFFLINE
_SYSSMU20_3705739785$          UNDOTBS02            ONLINE
_SYSSMU19_3920348761$          UNDOTBS02            ONLINE
_SYSSMU18_2539622763$          UNDOTBS02            ONLINE
_SYSSMU17_178842559$           UNDOTBS02            ONLINE
_SYSSMU16_3035903491$          UNDOTBS02            ONLINE
_SYSSMU15_444141832$           UNDOTBS02            ONLINE
_SYSSMU14_3021863913$          UNDOTBS02            ONLINE
_SYSSMU13_3717211136$          UNDOTBS02            ONLINE
_SYSSMU12_3182721254$          UNDOTBS02            ONLINE
_SYSSMU11_3909920883$          UNDOTBS02            ONLINE
通过以下可以看到不同的数字对应不同的状态:
undo segment 的状态:
1表示offline并且被删除
2 表示offline
3 表示online
4 未知
5 表示need recovery
SYS@orcl11g>select name,status$ from undo$;
NAME                                                            STATUS$
------------------------------------------------------------ ----------
SYSTEM                                                                3
_SYSSMU1_3780397527$                                                  2
_SYSSMU2_2232571081$                                                  2
_SYSSMU3_2097677531$                                                  2
_SYSSMU4_1152005954$                                                  2
_SYSSMU5_1527469038$                                                  2
_SYSSMU6_2443381498$                                                  2
_SYSSMU7_3286610060$                                                  2
_SYSSMU8_2012382730$                                                  2
_SYSSMU9_1424341975$                                                  2
_SYSSMU10_3550978943$                                                 3
_SYSSMU11_3909920883$                                                 3
_SYSSMU12_3182721254$                                                 3
_SYSSMU13_3717211136$                                                 3
_SYSSMU14_3021863913$                                                 3
_SYSSMU15_444141832$                                                  3
_SYSSMU16_3035903491$                                                 3
_SYSSMU17_178842559$                                                  3
_SYSSMU18_2539622763$                                                 3
_SYSSMU19_3920348761$                                                 3
_SYSSMU20_3705739785$                                                 3
强制将该回滚段offline,发现还是无法删除:
SYS@orcl11g>alter rollback segment "_SYSSMU10_3550978943$" offline;

Rollback segment altered.

SYS@orcl11g>drop tablespace UNDOTBS1;
drop tablespace UNDOTBS1
*
ERROR at line 1:
ORA-30013: undo tablespace 'UNDOTBS1' is currently in use
此时,我们关闭数据库使用bbed更改该回滚段的状态:
在数据库启动的时候,我们可以是oradebug 10046事件追踪,通过trace文件分析:
PARSING IN CURSOR #2 len=142 dep=1 uid=0 oct=3 lid=0 tim=1414654507002840 hv=361892850 ad=
首页 上一页 1 2 3 4 下一页 尾页 1/4/4
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇PostgreSQL启动过程中的那些事七.. 下一篇MongoDBJava连接

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: