IT博客汇
  • 首页
  • 精华
  • 技术
  • 设计
  • 资讯
  • 扯淡
  • 权利声明
  • 登录 注册

    错误操作导致数据文件丢失—alter database create datafile

    惜分飞发表于 2016-12-16 15:31:29
    love 0

    联系:手机(13429648788) QQ(107644445)

    链接:http://www.orasos.com/alter-database-create-datafile.html

    标题:错误操作导致数据文件丢失—alter database create datafile

    作者:惜分飞©版权所有[文章允许转载,但必须以链接方式注明源地址,否则追究法律责任.]

    alter database create datafile导致原始数据文件丢失
    有客户一个小系统找我们恢复,通过Oracle Database Recovery Check 检测之后我们红框部分发现一奇怪现象
    ctl
    create-datafile-ctl
    create-datafile


    1.文件头fuzzy为NO,不符合数据库异常crash常识,也和其他文件该状态不匹配
    2.文件的创建时间,scn均和checkpoint时间,scn一致(也就是说该文件是创建之后就checkpoint,然后就没有其他操作)
    3.文件开始应用的归档为5,110和其他数据文件要求的3115相差甚远
    结合这些情况,怀疑该文件被重新创建,查找alert日志果如发现如下信息
    两个文件通过create datafile创建之后,然后offline操作.通过alert日志核查file 6和8的创建时间和seq信息
    1
    Fri Jan 16 15:03:36 2015
    Thread 1 advanced to log sequence 5 (LGWR switch)
      Current log# 2 seq# 5 mem# 0: D:\APP\ADMINISTRATOR\ORADATA\MYCHOICE\REDO02.LOG
    Fri Jan 16 15:13:19 2015
    CREATE BIGFILE TABLESPACE "FBAUDIT"
    DATAFILE 'E:\ZDSoft\ZDFood\databak\FBAUDIT' SIZE 10M
    AUTOEXTEND ON NEXT 10M
    MAXSIZE UNLIMITED LOGGING EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO
    Completed: CREATE BIGFILE TABLESPACE "FBAUDIT"
    DATAFILE 'E:\ZDSoft\ZDFood\databak\FBAUDIT' SIZE 10M
    AUTOEXTEND ON NEXT 10M
    MAXSIZE UNLIMITED LOGGING EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO
    
    Sat Feb 07 15:03:46 2015
    Thread 1 advanced to log sequence 110 (LGWR switch)
      Current log# 2 seq# 110 mem# 0: D:\APP\ADMINISTRATOR\ORADATA\MYCHOICE\REDO02.LOG
    Sat Feb 07 15:20:41 2015
    CREATE BIGFILE TABLESPACE "CARD"
    DATAFILE 'E:\ZDSoft\ZDCARD\databak\CARD1' SIZE 10M
    AUTOEXTEND ON NEXT 10M
    MAXSIZE UNLIMITED LOGGING EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO
    Completed: CREATE BIGFILE TABLESPACE "CARD"
    DATAFILE 'E:\ZDSoft\ZDCARD\databak\CARD1' SIZE 10M
    AUTOEXTEND ON NEXT 10M
    MAXSIZE UNLIMITED LOGGING EXTENT MANAGEMENT LOCAL SEGMENT SPACE MANAGEMENT AUTO
    

    通过结合alert日志判断,我们可以确定,当前我们Oracle Database Recovery Check检查出来的情况,是由于执行了create datafile命令导致故障前的文件丢失,创建了一个新的数据文件,而由于该库为非归档模式,导致该文件数据无法恢复(备注:不光是非归档模式不行,就算是归档模式,也需要从文件创建到现在的所有归档才行).在大部分生产系统,我相信不可能有这么的归档,因为在执行alter database create datafile命令之时一定要慎重,评估确定是否丢失归档,否则可能导致不可理的损坏).
    客户意识到了悲剧的发生,但是希望我们帮忙恢复一张核心数据,用户的余额信息.

    对于alter database create datafile丢失文件恢复
    通过工具扫描原始文件相关的记录(由于写入大量数据,无法完整恢复,只能通过工具扫描,恢复部分数据)[asm disk header 彻底损坏恢复]
    scan-datafile


    因为原库虽然丢失了这两个文件,但是已经open成功,通过相关的data obj结合这个里面扫描到的文件,抽取出来需要的对象的block,然后对block里面的数据进行读取恢复出来相关数据.在这里我们还有一个难点就是由于这两个文件都是bigfile,给恢复过程增加了难度
    recover-data

    至此我们已经实现了对于alter database create datafile导致文件丢失的核心数据的恢复.尽可能的减小的客户的损坏.这种恢复是取决运气,数据在磁盘上的block没有被覆盖.如果覆盖了基本无望.
    如果需要数据库恢复,请联系我们(ORACLE数据库恢复技术支持),将为您提供专业数据库技术支持:
    Phone:13429648788    Q Q:107644445    E-Mail:dba@xifenfei.com
    再次提醒
    1.在数据库出现故障之时,尽可能保护现场,做操作之前要之后后果别百度了就不分青红皂白的直接操作,导致不可逆的破坏,数据可能永久性丢失[Oracle异常恢复前备份保护现场建议—FileSystem环境|Oracle异常恢复前备份保护现场建议—ASM环境
    2.使用alter database create datafile命令之前需要慎重,评估是否所有的归档都存在

    • Oracle安全警示录:加错裸设备导致redo异常
    • bbed for win 64
    • 误drop tablespace后使用flashback database闪回异常处理
    • ORA-01245 ORA-01110 恢复
    • _OFFLINE_ROLLBACK_SEGMENTS _CORRUPTED_ROLLBACK_SEGMENTS
    • ORACLE 7.3.4 截图欣赏
    • 通过多次resetlogs规避类似ORA-01248: file N was created in the future of incomplete recovery错误
    • Oracle 8i安装过程截图
    • Oracle 8.0.5 安装过程截图
    • ORACLE 12C安装预览
    • 深入分析一次ORA-00314错误
    • oracle asm系列文章汇总—www.xifenfie.com
    • Linux中安装DB2截图欣赏
    • statspack安装
    • 达梦数据库命令行工具


沪ICP备19023445号-2号
友情链接