通过句柄恢复Linux下误删除的数据库数据文件

本文详细介绍了一次意外删除Oracle数据库数据文件后的恢复过程。包括创建测试环境、模拟数据文件删除、查找并恢复数据文件等关键步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

环境介绍:

OS:Redhat EnterPrise 5.4
DB:Oracle EnterPrise Database 11gR2(11.2.3.0)


       在数据库正常运行时,运维人员在无意中将部分数据文件删除了,此时数据库管理员并不知道,且数据库运行正常,并没有立即抛出错误和告警;但是开发人员在对某张表进行更新的时候,正好这张表在被删除的数据文件中,报出ORA-01110和ORA-27041错误。随即数据库管理人员来看现象,发现有一个文件已经从系统层面删除了,并且数据库数据库没有进行重启操作,所以在没有进行更新的时候业务并没有造成影响。

非常幸运的是,在数据文件删除的情况下,数据库没有重启,使得这次的恢复变的较为简单,基于这次的恢复,我在我得实验设备上进行了重演,记录了完整的数据文件删除和恢复的完整步骤,如下:


一、准备测试环境,创建新的表空间及数据文件:

  1. SQL> create tablespace woo datafile
  2.   2 '/u01/app/oracle/oradata/PROD1/woo01.dbf'
  3.   3 size 20m autoextend on;

  4. Tablespace created.

  5. SQL> select name from v$dbfile;

  6. NAME
  7. --------------------------------------------------------------------------------
  8. /u01/app/oracle/oradata/PROD1/users01.dbf
  9. /u01/app/oracle/oradata/PROD1/undotbs01.dbf
  10. /u01/app/oracle/oradata/PROD1/sysaux01.dbf
  11. /u01/app/oracle/oradata/PROD1/system01.dbf
  12. /u01/app/oracle/oradata/PROD1/example01.dbf
  13. /u01/app/oracle/oradata/PROD1/tools.dbf
  14. /u01/app/oracle/oradata/PROD1/test.dbf
  15. /u01/app/oracle/oradata/PROD1/woo01.dbf

  16. 8 rows selected.

二、模拟故障,在系统级别删除数据文件:

  1. SQL> !rm -rf /u01/app/oracle/oradata/PROD1/woo01.dbf

三、检查数据库状态,并且创建测试数据

  1. SQL> !tail -100f /u01/app/oracle/diag/rdbms/prod1/PROD1/trace/alert*

  2. Wed Aug 26 14:31:01 2015
  3. create tablespace woo datafile
  4. '/u01/app/oracle/oradata/PROD1/woo01.dbf'
  5. size 20m autoextend on
  6. Completed: create tablespace woo datafile
  7. '/u01/app/oracle/oradata/PROD1/woo01.dbf'
  8. size 20m autoextend on

  9. #在这里我们可以看到数据文件在系统层面被删除之后数据库并没产生告警。


  10. SQL> create table test tablespace woo as select * from dba_users;
  11. create table test tablespace woo as select * from dba_users
  12.                                                   *
  13. ERROR at line 1:
  14. ORA-01116: error in opening database file 8
  15. ORA-01110: data file 8: '/u01/app/oracle/oradata/PROD1/woo01.dbf'
  16. ORA-27041: unable to open file
  17. Linux Error: 2: No such file or directory
  18. Additional information: 3


  19. #而使在我们需要往这个删除的文件中写入数据的时候才发现数据文件被删除了。

  20. SQL> !tail -50 /u01/app/oracle/diag/rdbms/prod1/PROD1/trace/alert*

  21. Wed Aug 26 14:34:33 2015
  22. Errors in file /u01/app/oracle/diag/rdbms/prod1/PROD1/trace/PROD1_smon_9564.trc:
  23. ORA-01116: error in opening database file 8
  24. ORA-01110: data file 8: '/u01/app/oracle/oradata/PROD1/woo01.dbf'
  25. ORA-27041: unable to open file
  26. Linux Error: 2: No such file or directory
  27. Additional information: 3
  28. Wed Aug 26 14:34:33 2015
  29. Checker run found 1 new persistent data failures
  30. Wed Aug 26 14:39:44 2015
  31. Errors in file /u01/app/oracle/diag/rdbms/prod1/PROD1/trace/PROD1_m000_14015.trc:
  32. ORA-01116: error in opening database file 8
  33. ORA-01110: data file 8: '/u01/app/oracle/oradata/PROD1/woo01.dbf'
  34. ORA-27041: unable to open file
  35. Linux Error: 2: No such file or directory
  36. Additional information: 3


  37. SQL> select instance_name,status from v$instance;

  38. INSTANCE_NAME STATUS
  39. ---------------- ------------
  40.         PROD1 OPEN                                     #即便数据库已经知道了数据库文件丢失,因为不是系统表空间的数据文件,所以数据库的运行并没有收到影响。

四、查找数据文件

        因为数据库并没有停止运行,这个时候我们可以通过dbwr写数据文件进程来找到进程句柄号,进入该句柄号就可以找到该进程锁定的相关数据文件了。


  1. SQL> !ps -ef|grep dbw|grep -v grep
  2. oracle 9554 1 0 07:16 ? 00:00:01 ora_dbw0_PROD1

  3. #我们可以看到进程的ID为9554,通过进程ID查找到进程下锁定的所有文件
  4. SQL> !ls -rtl /proc/9554/fd

  5. [oracle@edbjr2p1 trace]$ ls -rtl /proc//9554/fd
  6. total 0
  7. lr-x------ 1 oracle oinstall 64 Aug 26 14:37 0 -> /dev/null
  8. lr-x------ 1 oracle oinstall 64 Aug 26 14:37 9 -> /dev/null
  9. lr-x------ 1 oracle oinstall 64 Aug 26 14:37 8 -> /u01/app/oracle/product/11.2.0/dbhome_1/bin/oracle
  10. lr-x------ 1 oracle oinstall 64 Aug 26 14:37 7 -> /dev/null
  11. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 6 -> /u01/app/oracle/product/11.2.0/dbhome_1/hpatch/orapatchPROD1.cfg
  12. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 5 -> /u01/app/oracle/product/11.2.0/dbhome_1/dbs/hc_PROD1.dat
  13. lr-x------ 1 oracle oinstall 64 Aug 26 14:37 4 -> /dev/null
  14. lr-x------ 1 oracle oinstall 64 Aug 26 14:37 3 -> /dev/null
  15. l-wx------ 1 oracle oinstall 64 Aug 26 14:37 2 -> /dev/null
  16. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 19 -> /u01/app/oracle/product/11.2.0/dbhome_1/hpatch/orapatchPROD1.cfg
  17. lr-x------ 1 oracle oinstall 64 Aug 26 14:37 18 -> /proc/9554/fd
  18. lr-x------ 1 oracle oinstall 64 Aug 26 14:37 17 -> /u01/app/oracle/product/11.2.0/dbhome_1/rdbms/mesg/oraus.msb
  19. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 16 -> /u01/app/oracle/product/11.2.0/dbhome_1/dbs/hc_PROD1.dat
  20. lr-x------ 1 oracle oinstall 64 Aug 26 14:37 15 -> /u01/app/oracle/product/11.2.0/dbhome_1/bin/oracle
  21. lr-x------ 1 oracle oinstall 64 Aug 26 14:37 14 -> /dev/zero
  22. lr-x------ 1 oracle oinstall 64 Aug 26 14:37 13 -> /dev/zero
  23. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 12 -> /u01/app/oracle/product/11.2.0/dbhome_1/hpatch/orapatchPROD1.cfg
  24. lr-x------ 1 oracle oinstall 64 Aug 26 14:37 11 -> /dev/null
  25. lr-x------ 1 oracle oinstall 64 Aug 26 14:37 10 -> /dev/null
  26. l-wx------ 1 oracle oinstall 64 Aug 26 14:37 1 -> /dev/null
  27. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 268 -> /u01/app/oracle/oradata/PROD1/woo01.dbf (deleted) //我们找到了这个文件,处于deleted
  28. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 267 -> /u01/app/oracle/oradata/PROD1/temp2.dbf
  29. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 266 -> /u01/app/oracle/oradata/PROD1/temp1.dbf
  30. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 265 -> /u01/app/oracle/oradata/PROD1/temp01.dbf
  31. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 264 -> /u01/app/oracle/oradata/PROD1/test.dbf
  32. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 263 -> /u01/app/oracle/oradata/PROD1/tools.dbf
  33. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 262 -> /u01/app/oracle/oradata/PROD1/example01.dbf
  34. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 261 -> /u01/app/oracle/oradata/PROD1/users01.dbf
  35. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 260 -> /u01/app/oracle/oradata/PROD1/undotbs01.dbf
  36. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 259 -> /u01/app/oracle/oradata/PROD1/sysaux01.dbf
  37. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 258 -> /u01/app/oracle/oradata/PROD1/system01.dbf
  38. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 257 -> /u01/app/oracle/oradata/PROD1/control02.ctl
  39. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 256 -> /u01/app/oracle/oradata/PROD1/control01.ctl
  40. lr-x------ 1 oracle oinstall 64 Aug 26 14:37 24 -> /u01/app/oracle/product/11.2.0/dbhome_1/rdbms/mesg/oraus.msb
  41. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 23 -> /u01/app/oracle/product/11.2.0/dbhome_1/dbs/lkPROD1
  42. lrwx------ 1 oracle oinstall 64 Aug 26 14:37 22 -> /u01/app/oracle/product/11.2.0/dbhome_1/dbs/hc_PROD1.dat
  43. lr-x------ 1 oracle oinstall 64 Aug 26 14:37 21 -> /u01/app/oracle/product/11.2.0/dbhome_1/bin/oracle
  44. lr-x------ 1 oracle oinstall 64 Aug 26 14:37 20 -> /dev/zero
  45. lrwx------ 1 oracle oinstall 64 Aug 26 15:09 25 -> socket:[173283]

五、将该文件句柄拷贝到原文件位置:

  1. SQL> !cp /proc//9554/fd/268 /u01/app/oracle/oradata/PROD1/woo01.dbf

六、对拷贝回来的文件执行常规的数据恢复操作,实际上也就是更新下数据文件头部的scn号:

  1. SQL> col name format a50
  2. SQL> select file#,status,name from v$datafile;

  3.      FILE# STATUS NAME
  4. ---------- ------- --------------------------------------------------
  5.          1 SYSTEM /u01/app/oracle/oradata/PROD1/system01.dbf
  6.          2 ONLINE /u01/app/oracle/oradata/PROD1/sysaux01.dbf
  7.          3 ONLINE /u01/app/oracle/oradata/PROD1/undotbs01.dbf
  8.          4 ONLINE /u01/app/oracle/oradata/PROD1/users01.dbf
  9.          5 ONLINE /u01/app/oracle/oradata/PROD1/example01.dbf
  10.          6 ONLINE /u01/app/oracle/oradata/PROD1/tools.dbf
  11.          7 ONLINE /u01/app/oracle/oradata/PROD1/test.dbf
  12.          8 ONLINE /u01/app/oracle/oradata/PROD1/woo01.dbf     #我们可以看到这个时候该数据文件是ONLINE状态

  13. 8 rows selected.


  14. #由于这是一套在线库,且有其它业务,不可随意停机,所以这个时候将需要恢复的数据文件offline,就可以直接在线执行恢复了。

  15. SQL> alter database datafile 8 offline;

  16. Database altered.

  17. SQL> select file#,status,name from v$datafile;

  18.      FILE# STATUS NAME
  19. ---------- ------- --------------------------------------------------
  20.          1 SYSTEM /u01/app/oracle/oradata/PROD1/system01.dbf
  21.          2 ONLINE /u01/app/oracle/oradata/PROD1/sysaux01.dbf
  22.          3 ONLINE /u01/app/oracle/oradata/PROD1/undotbs01.dbf
  23.          4 ONLINE /u01/app/oracle/oradata/PROD1/users01.dbf
  24.          5 ONLINE /u01/app/oracle/oradata/PROD1/example01.dbf
  25.          6 ONLINE /u01/app/oracle/oradata/PROD1/tools.dbf
  26.          7 ONLINE /u01/app/oracle/oradata/PROD1/test.dbf
  27.          8 RECOVER /u01/app/oracle/oradata/PROD1/woo01.dbf #在对数据文件进行操作,触发了该文件,发现文件头部的scn不一致,提示需要进行恢复。’

  28. 8 rows selected.

  29. #执行在线恢复并且online该数据文件。

  30. SQL> recover datafile 8;
  31. Media recovery complete.
  32. SQL> alter database datafile 8 online;

  33. Database altered.

七、验证数据文件恢复后是否可以正常使用

  1. SQL> select file#,status,name from v$datafile;

  2.      FILE# STATUS NAME
  3. ---------- ------- --------------------------------------------------
  4.          1 SYSTEM /u01/app/oracle/oradata/PROD1/system01.dbf
  5.          2 ONLINE /u01/app/oracle/oradata/PROD1/sysaux01.dbf
  6.          3 ONLINE /u01/app/oracle/oradata/PROD1/undotbs01.dbf
  7.          4 ONLINE /u01/app/oracle/oradata/PROD1/users01.dbf
  8.          5 ONLINE /u01/app/oracle/oradata/PROD1/example01.dbf
  9.          6 ONLINE /u01/app/oracle/oradata/PROD1/tools.dbf
  10.          7 ONLINE /u01/app/oracle/oradata/PROD1/test.dbf
  11.          8 ONLINE /u01/app/oracle/oradata/PROD1/woo01.dbf

  12. 8 rows selected.

  13. SQL> create table test tablespace woo as select * from dba_users;

  14. Table created.

八、至此完成该数据文件的恢复



来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/20674423/viewspace-1783254/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/20674423/viewspace-1783254/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值