1、测试环境准备
[oracle@redhat3 ~]$ uname -a
Linux redhat3 2.6.32-573.el6.x86_64 #1 SMP Wed Jul 1 18:23:37 EDT 2015 x86_64 x86_64 x86_64 GNU/Linux
[oracle@redhat3 ~]$ sqlplus / as sysdba
set pagesize 999

SQL*Plus: Release 11.2.0.4.0 Production on Fri Mar 16 05:13:19 2018

Copyright (c) 1982, 2013, Oracle. All rights reserved.

Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options

SQL> SQL> select * from v$version;

BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
PL/SQL Release 11.2.0.4.0 - Production
CORE 11.2.0.4.0 Production
TNS for Linux: Version 11.2.0.4.0 - Production
NLSRTL Version 11.2.0.4.0 - Production

创建专门的表空间、用户和数据表,用于进行试验。
create tablespace rmdtest datafile '/u01/app/oracle/oradata/inf/rmdtest01.dbf' size 50m extent management local uniform size 1m segment space management auto;

create user rmtest identified by rmtest default tablespace rmdtest;
grant resource, connect to rmtest;
grant select any dictionary to rmtest;

conn rmtest/rmtest
create table rm_tab as select * from dba_objects;
insert into rm_tab select * from rm_tab;

select tablespace_name, bytes/1024/1024 M from dba_segments where owner='RMTEST' and segment_name='RM_TAB';

2、开始实验
删除数据文件。
[oracle@redhat3 inf]$ rm rmdtest01.dbf

删除之后,借助文件描述符,我们还是可以查询的。
SQL> SQL> select count(*) from rmtest.rm_tab;

COUNT(*)
----------
173304
查找dbwr进程,确定进程编号。
[oracle@redhat3 inf]$ ps -ef | grep dbw
oracle 2537 1 0 04:24 ? 00:00:00 ora_dbw0_inf
oracle 3313 2925 0 05:33 pts/0 00:00:00 grep dbw
使用lsof –p确定文件描述符信息。
[oracle@redhat3 inf]$ lsof -p 2537
oracle 2537 oracle 256u REG 253,0 10043392 651611 /u01/app/oracle/oradata/inf/control01.ctl
oracle 2537 oracle 257u REG 253,0 10043392 651613 /u01/app/oracle/fast_recovery_area/inf/control02.ctl
oracle 2537 oracle 258uW REG 253,0 817897472 651602 /u01/app/oracle/oradata/inf/system01.dbf
oracle 2537 oracle 259uW REG 253,0 566239232 651604 /u01/app/oracle/oradata/inf/sysaux01.dbf
oracle 2537 oracle 260uW REG 253,0 471867392 651606 /u01/app/oracle/oradata/inf/undotbs01.dbf
oracle 2537 oracle 261uW REG 253,0 9183232 651608 /u01/app/oracle/oradata/inf/users01.dbf
oracle 2537 oracle 262uW REG 253,0 2252349440 655877 /u01/app/oracle/oradata/inf/inf01.dbf
oracle 2537 oracle 264uW REG 253,0 81797120 651634 /u01/app/oracle/oradata/inf/temp01.dbf
oracle 2537 oracle 265uW REG 253,0 52436992 657854 /u01/app/oracle/oradata/inf/rmdtest01.dbf (deleted)

注意:lsof是描述文件描述符最好的工具,其中包括FD列。我们从dbwr的连接中,找到了rmdtest01.dbf的信息行。其中FD=265uW。这个265就表示了连接文件的名称。
联合dbwr的进程编号2537,我们在目录/proc/2537/fd中找到所有的文件符。
[oracle@redhat3 inf]$ cd /proc/2537/fd
[oracle@redhat3 fd]$
[oracle@redhat3 fd]$ pwd
/proc/2537/fd
[oracle@redhat3 fd]$ ls -l
total 0
lr-x------ 1 oracle oinstall 64 Mar 16 05:35 0 -> /dev/null
l-wx------ 1 oracle oinstall 64 Mar 16 05:35 1 -> /dev/null
lrwx------ 1 oracle oinstall 64 Mar 16 05:35 10 -> /u01/app/oracle/11.2.0.4/dbs/lkINF
lr-x------ 1 oracle oinstall 64 Mar 16 05:35 11 -> /u01/app/oracle/11.2.0.4/rdbms/mesg/oraus.msb
lrwx------ 1 oracle oinstall 64 Mar 16 05:35 12 -> socket:[20147]
l-wx------ 1 oracle oinstall 64 Mar 16 05:35 2 -> /dev/null
lrwx------ 1 oracle oinstall 64 Mar 16 05:35 256 -> /u01/app/oracle/oradata/inf/control01.ctl
lrwx------ 1 oracle oinstall 64 Mar 16 05:35 257 -> /u01/app/oracle/fast_recovery_area/inf/control02.ctl
lrwx------ 1 oracle oinstall 64 Mar 16 05:35 258 -> /u01/app/oracle/oradata/inf/system01.dbf
lrwx------ 1 oracle oinstall 64 Mar 16 05:35 259 -> /u01/app/oracle/oradata/inf/sysaux01.dbf
lrwx------ 1 oracle oinstall 64 Mar 16 05:35 260 -> /u01/app/oracle/oradata/inf/undotbs01.dbf
lrwx------ 1 oracle oinstall 64 Mar 16 05:35 261 -> /u01/app/oracle/oradata/inf/users01.dbf
lrwx------ 1 oracle oinstall 64 Mar 16 05:35 262 -> /u01/app/oracle/oradata/inf/inf01.dbf
lrwx------ 1 oracle oinstall 64 Mar 16 05:35 264 -> /u01/app/oracle/oradata/inf/temp01.dbf
lrwx------ 1 oracle oinstall 64 Mar 16 05:35 265 -> /u01/app/oracle/oradata/inf/rmdtest01.dbf (deleted)
lr-x------ 1 oracle oinstall 64 Mar 16 05:35 3 -> /dev/null
lr-x------ 1 oracle oinstall 64 Mar 16 05:35 4 -> /dev/null
lr-x------ 1 oracle oinstall 64 Mar 16 05:35 5 -> /dev/null
lr-x------ 1 oracle oinstall 64 Mar 16 05:35 6 -> /u01/app/oracle/11.2.0.4/rdbms/mesg/oraus.msb
lr-x------ 1 oracle oinstall 64 Mar 16 05:35 7 -> /proc/2537/fd
lr-x------ 1 oracle oinstall 64 Mar 16 05:35 8 -> /dev/zero
lrwx------ 1 oracle oinstall 64 Mar 16 05:35 9 -> /u01/app/oracle/11.2.0.4/dbs/hc_inf.dat

这个265对应的文件还存在,就是已经被删除的那个rmdtest01.dbf文件。进行拷贝出来。
[oracle@redhat3 fd]# cp 265 /u01/app/oracle/oradata/inf/rmdtest01res.dbf
[oracle@redhat3 inf]$ pwd
/u01/app/oracle/oradata/inf
[oracle@redhat3 inf]$ ll
total 4318668
-rw-r----- 1 oracle oinstall 10043392 Mar 16 05:52 control01.ctl
-rw-r----- 1 oracle oinstall 2252349440 Mar 16 05:30 inf01.dbf
-rw-r----- 1 oracle oinstall 52429312 Jan 29 06:54 redo01.log
-rw-r----- 1 oracle oinstall 52429312 Mar 16 05:30 redo02.log
-rw-r----- 1 oracle oinstall 52429312 Mar 16 05:51 redo03.log
-rw-r----- 1 oracle oinstall 52436992 Mar 16 05:50 rmdtest01res.dbf
-rw-r----- 1 oracle oinstall 566239232 Mar 16 05:47 sysaux01.dbf
-rw-r----- 1 oracle oinstall 817897472 Mar 16 05:37 system01.dbf
-rw-r----- 1 oracle oinstall 81797120 Mar 14 10:32 temp01.dbf
-rw-r----- 1 oracle oinstall 5251072 Dec 22 10:36 test01.dbfbak
-rw-r----- 1 oracle oinstall 471867392 Mar 16 05:47 undotbs01.dbf
-rw-r----- 1 oracle oinstall 9183232 Mar 16 05:30 users01.dbf

拷贝出来之后,最好进行一定转换。先将其offline,之后进行控制文件中的rename动作,最后recover和online操作。具体流程常见笔者专门的文章

SQL> select TABLESPACE_NAME,FILE_ID,STATUS,FILE_NAME,BYTES/1024/1024 from dba_data_files;

TABLESPACE_NAME FILE_ID STATUS FILE_NAME BYTES/1024/1024
-------------------- ---------- --------- ------------------------------------------------------------ ---------------
RMDTEST 7 AVAILABLE /u01/app/oracle/oradata/inf/rmdtest01.dbf 50
USERS 4 AVAILABLE /u01/app/oracle/oradata/inf/users01.dbf 8.75
UNDOTBS1 3 AVAILABLE /u01/app/oracle/oradata/inf/undotbs01.dbf 450
SYSAUX 2 AVAILABLE /u01/app/oracle/oradata/inf/sysaux01.dbf 540
SYSTEM 1 AVAILABLE /u01/app/oracle/oradata/inf/system01.dbf 780
INF 5 AVAILABLE /u01/app/oracle/oradata/inf/inf01.dbf 2148

SQL> alter database datafile 7 offline;

Database altered.

SQL> alter database rename file '/u01/app/oracle/oradata/inf/rmdtest01.dbf' to '/u01/app/oracle/oradata/inf/rmdtest01res.dbf';

Database altered.

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

Database altered.

使用rman中的recovery advisor工具,来判断错误是否存在。
[oracle@redhat3 inf]$ rman target /

Recovery Manager: Release 11.2.0.4.0 - Production on Fri Mar 16 05:55:20 2018

Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved.

connected to target database: INF (DBID=2613824471)

RMAN> list failure;

using target database control file instead of recovery catalog
no failures found that match specification

Linux下利用文件描述符恢复的成功失败实验的更多相关文章

  1. Linux Linux下最大文件描述符设置

    Linux下最大文件描述符设置 by:授客 QQ:1033553122 1.   系统可打开最大文件描述符设置 查看系统可打开最大文件描述符 # cat /proc/sys/fs/file-max 6 ...

  2. Linux下的文件描述符

    文件描述符是一个简单的整数,用以标明每一个被进程所打开的文件和socket.第一个打开的文件是0,第二个是1,依此类推.Unix 操作系统通常给每个进程能打开的文件数量强加一个限制.更甚的是,unix ...

  3. Linux中的文件描述符与打开文件之间的关系

    Linux中的文件描述符与打开文件之间的关系 导读 内核(kernel)利用文件描述符(file descriptor)来访问文件.文件描述符是非负整数.打开现存文件或新建文件时,内核会返回一个文件描 ...

  4. Linux exec与文件描述符

    看到好几篇文章讲述exec都是一知半解,所以我尽量说的清楚明白一些.本文首先讲述Linux文件描述符,然后是exec,最后举例说明exec I/O重定向及其用法. 概念:exec命令用于调用并执行指令 ...

  5. Linux中的文件描述符与打开文件之间的关系------------每天进步一点点系列

    http://blog.csdn.net/cywosp/article/details/38965239 1. 概述     在Linux系统中一切皆可以看成是文件,文件又可分为:普通文件.目录文件. ...

  6. (转)Linux中的文件描述符

    本文转自:http://blog.csdn.net/cywosp/article/details/38965239 作者:cywosp 1. 概述 在Linux系统中一切皆可以看成是文件,文件又可分为 ...

  7. [svc]linux中的文件描述符(file descriptor)和文件

    linux中的文件描述符(file descriptor)和文件 linux为了实现一切皆文件的设计哲学,不仅将数据抽象成了文件,也将一切操作和资源抽象成了文件,比如说硬件设备,socket,磁盘,进 ...

  8. (转)Linux中的文件描述符与打开文件之间的关系

    转:http://blog.csdn.net/cywosp/article/details/38965239 1. 概述     在Linux系统中一切皆可以看成是文件,文件又可分为:普通文件.目录文 ...

  9. Linux系统编程--文件描述符的复制dup()和dup2()【转】

    本文转载自:http://blog.csdn.net/tennysonsky/article/details/45870459 dup() 和 dup2() 是两个非常有用的系统调用,都是用来复制一个 ...

随机推荐

  1. 一步步建立 Vue + Cesium 初始化项目

    一步步建立 Vue + Cesium 初始化项目 初始化 Vue 项目 升级 npm npm install -g npm 安装 @vue/cli 和 @vue/cli-service-global ...

  2. 向量 dot cross product 点积叉积 几何意义

    向量 dot cross product 点积叉积 几何意义 有向量 a b 点积 a * b = |a| * |b| * cosθ 几何意义: 1. a * b == 0,则 a ⊥ b 2. a ...

  3. 一次国际化记录以及平铺JSON数据

    ​ 写这个方法的原因是因为我们需要改版国际化,因为相同的项目有其他分支做过国际化,但是主版本没有进行过国际化,目前需要修改主版本的国际化,但是因为国际化的方式做了结构上的调整所以写了这个工具方法方便去 ...

  4. vw实现移动端自适应页面

    一.设备支持情况 测试网站:https://caniuse.com/#search=vw css3test:https://airen.github.io/css3test/,https://gith ...

  5. 关于Function Language(函数式语言是什么?包含哪些语言?为什么函数式语言流行?)

    1.What? Function Language是一种非冯诺依曼式的程序设计语言.函数式语言的主要成分是原始函数.定义函数和函数型. 这种语言具有较强的组织数据结构的能力,可以把某一数据结构(如数组 ...

  6. Auth模块、Forms组件

    Auth模块 auth模块是Django自带的用户认证模块: 我们在开发一个网站的时候,无可避免的需要设计实现网站的用户系统.此时我们需要实现包括用户注册.用户登录.用户认证.注销.修改密码等功能,这 ...

  7. npm的一些常用命令(在国内,建议使用cnpm,在淘宝镜像里面下载就行)

    npm的一些常用命令(在国内,npm操作可能会比较慢,建议使用cnpm,在淘宝镜像里面下载就行,用法和npm一样) cnpm安装地址,直接安装 npm install cnpm -g --regist ...

  8. vue_表单 input 的绑定

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. mysql百万级全文索引及match快速查找

    建立全文索引的表的存储引擎类型必须为MyISAM 问题是match   against对中文模糊搜索支持不是太好 新建一个utf8 MyISAM类型的表并建立一个全文索引  : CREATE TABL ...

  10. SEED实验——Environment Variable and Set-UID Program实验描述与实验任务

    第一部分:实验描述 该实验的学习任务是理解环境变量是如何影响程序和系统行为的.环境变量是一组动态命名的变量 第二部分:实验任务 2.1 任务一:操作环境变量 在这个任务中,我们研究可以用来设置和取消设 ...