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

简介: 环境介绍:OS:Redhat EnterPrise 5.4DB:Oracle EnterPrise Database 11gR2(11.2.3.0)       在数据库正常运行时,运维人员在无意中将部分数据文件删除了,此时数据库管理员并不知道,且数据库运行正常,并没有立即抛出错误和告警;但是开发人员在对某张表进行更新的时候,正好这张表在被删除的数据文件中,报出ORA-01110和ORA-27041错误。

环境介绍:

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


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

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


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

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

Tablespace created.

SQL> select name from v$dbfile;

NAME                                                                            
--------------------------------------------------------------------------------
/u01/app/oracle/oradata/PROD1/users01.dbf                                       
/u01/app/oracle/oradata/PROD1/undotbs01.dbf                                     
/u01/app/oracle/oradata/PROD1/sysaux01.dbf                                      
/u01/app/oracle/oradata/PROD1/system01.dbf                                      
/u01/app/oracle/oradata/PROD1/example01.dbf                                     
/u01/app/oracle/oradata/PROD1/tools.dbf                                         
/u01/app/oracle/oradata/PROD1/test.dbf                                          
/u01/app/oracle/oradata/PROD1/woo01.dbf                                         

8 rows selected.

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

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

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

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

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

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


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


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

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

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


SQL> select instance_name,status from v$instance;

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

四、查找数据文件

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

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

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

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

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

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

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

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

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

8 rows selected.


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

SQL> alter database datafile 8 offline;

Database altered.

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

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

8 rows selected.

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

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

Database altered.

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

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

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

8 rows selected.

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

Table created.

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

目录
相关文章
|
7天前
|
数据采集 数据库 Python
有哪些方法可以验证用户输入数据的格式是否符合数据库的要求?
有哪些方法可以验证用户输入数据的格式是否符合数据库的要求?
115 75
|
2月前
|
存储 监控 数据处理
flink 向doris 数据库写入数据时出现背压如何排查?
本文介绍了如何确定和解决Flink任务向Doris数据库写入数据时遇到的背压问题。首先通过Flink Web UI和性能指标监控识别背压,然后从Doris数据库性能、网络连接稳定性、Flink任务数据处理逻辑及资源配置等方面排查原因,并通过分析相关日志进一步定位问题。
224 61
|
1月前
|
Linux Shell 网络安全
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
本指南介绍如何利用 HTA 文件和 Metasploit 框架进行渗透测试。通过创建反向 shell、生成 HTA 文件、设置 HTTP 服务器和发送文件,最终实现对目标系统的控制。适用于教育目的,需合法授权。
73 9
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
|
23天前
|
Ubuntu Linux Go
golang编译成Linux可运行文件
本文介绍了如何在 Linux 上编译和运行 Golang 程序,涵盖了本地编译和交叉编译的步骤。通过这些步骤,您可以轻松地将 Golang 程序编译成适合 Linux 平台的可执行文件,并在目标服务器上运行。掌握这些技巧,可以提高开发和部署 Golang 应用的效率。
175 14
|
22天前
|
关系型数据库 MySQL Linux
Linux下mysql数据库的导入与导出以及查看端口
本文详细介绍了在Linux下如何导入和导出MySQL数据库,以及查看MySQL运行端口的方法。通过这些操作,用户可以轻松进行数据库的备份与恢复,以及确认MySQL服务的运行状态和端口。掌握这些技能,对于日常数据库管理和维护非常重要。
86 8
|
22天前
|
存储 NoSQL Linux
linux积累-core文件是干啥的
核心文件是Linux系统在程序崩溃时生成的重要调试文件,通过分析核心文件,开发者可以找到程序崩溃的原因并进行调试和修复。本文详细介绍了核心文件的生成、配置、查看和分析方法
77 6
|
24天前
|
存储 NoSQL Linux
linux之core文件如何查看和调试
通过设置和生成 core 文件,可以在程序崩溃时获取详细的调试信息。结合 GDB 等调试工具,可以深入分析 core 文件,找到程序崩溃的具体原因,并进行相应的修复。掌握这些调试技巧,对于提高程序的稳定性和可靠性具有重要意义。
178 6
|
20天前
|
SQL 存储 运维
从建模到运维:联犀如何完美融入时序数据库 TDengine 实现物联网数据流畅管理
本篇文章是“2024,我想和 TDengine 谈谈”征文活动的三等奖作品。文章从一个具体的业务场景出发,分析了企业在面对海量时序数据时的挑战,并提出了利用 TDengine 高效处理和存储数据的方法,帮助企业解决在数据采集、存储、分析等方面的痛点。通过这篇文章,作者不仅展示了自己对数据处理技术的理解,还进一步阐释了时序数据库在行业中的潜力与应用价值,为读者提供了很多实际的操作思路和技术选型的参考。
32 1
|
24天前
|
存储 Java easyexcel
招行面试:100万级别数据的Excel,如何秒级导入到数据库?
本文由40岁老架构师尼恩撰写,分享了应对招商银行Java后端面试绝命12题的经验。文章详细介绍了如何通过系统化准备,在面试中展示强大的技术实力。针对百万级数据的Excel导入难题,尼恩推荐使用阿里巴巴开源的EasyExcel框架,并结合高性能分片读取、Disruptor队列缓冲和高并发批量写入的架构方案,实现高效的数据处理。此外,文章还提供了完整的代码示例和配置说明,帮助读者快速掌握相关技能。建议读者参考《尼恩Java面试宝典PDF》进行系统化刷题,提升面试竞争力。关注公众号【技术自由圈】可获取更多技术资源和指导。
|
27天前
|
前端开发 JavaScript 数据库
获取数据库中字段的数据作为下拉框选项
获取数据库中字段的数据作为下拉框选项
54 5

热门文章

最新文章