Oracle中修复数据块的损坏

发表于:2010-1-28 09:46

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:未知    来源:51Testing软件测试网采编

#
Oracle

  1、先创建一个用于实验的表空间

  create tablespace block datafile size 1M extent management local;  –因为是11g所以使用了AMS

  alter user ff default tablespace block;

  alter user ff quota unlimited on block;

  2、损坏数据文件

  关闭database后用编辑器随便修改几个字符,然后启动database

  当访问相关被损坏的block时,将会遇到错误

  3、对此使用dbv检查数据文件

  dbv file=block.dbf blocksize=8192

  假设获得第35块被损坏了

  4、恢复步骤

  ①select tablespace_name, segment_type, owner, segment_name from dba_extents where file_id=4 and 35 between block_id and block_id+blocks-1;

  如果确定损失的是数据,就ok

  设置内部事件,设置在全表扫描时跳过损坏的数据块

  alter system set events=’10231 trace name context forever,level 10′;

  随后,可以用exp和imp进行导入导出,进行恢复。但这毕竟导致相依blocks中数据的丢失。

  ②rman的块媒体恢复(BMR)

  使用BMR恢复可以大量降低恢复的时间,可以使datafile仍然处于在线的状态。RMAN在BMR恢复时,先在full或level 0的备份集中查询相应的块的内容,并恢复,随后使用 redo log进行恢复,而不使用level 1备份集。

  在恢复之前,首先要查找到corrupt blocks:在db中,v$database_block_corruption 视图显示了rman、analyze、dbv和sql查询等操作中获悉的corrupt block信息。此视图记录的记录数据有两类:

  *物理的corruption:无法辨识该数据块,checksum、header、footer校验错误

  *逻辑corruption:chechsum、header、footer校验是正确的,但是该数据块的内容时不一致的。

  注意:BMR是不能用于恢复逻辑上的corruption的。在backup命令中checksum的校验是

  默认开启的,可以通过NOCHECKSUM选项属性关闭。逻辑的校验默认是关闭的,可以

  在backup、restore、recover、validate命令中添加CHECK LOGICAL开启。

  @@进行BMR的条件

  1)target db必须运行在归档模式下,并以当前的控制文件open或mounted

  2)If the target database is a standby database, then it must be in a consistent state, recovery cannot be in session, and the backup must be older than the corrupted file.

  3)数据文件的备份集必须是full或level 0

  4)对于BMR,rman只使用已经归档的redo logs

  5)flashback db开启时,rman可以用flashback logs查找corrupt block在corrupt之前的镜像,用于恢复,加快恢复速度。

  使用恢复命令恢复指定的数据块

《2023软件测试行业现状调查报告》独家发布~

精彩评论

  • 最初的梦想666
    2010-1-28 14:20:00

    招聘:
    知名外资公司,SQL 职位,Manager / Lead /SSE/SE , 英语好,考虑新机会的可给我发简历(也欢迎推荐)

    邮箱:happyzs9@163.com  , MSN: happyzs9@163.com

  • bingyi8589
    2010-1-28 10:08:28

    ding

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号