位置: 编程技术 - 正文

Linux(Unix)中误删除的文件恢复方法(linux误删文件怎么办)

编辑:rootadmin
在Linux下大致重新演示一下恢复的过程,恢复的步骤与数据库版本没有太大关系,与操作系统的不同会有所不同。 1. 在数据库open的时候,直接删除users表空间中的数据文件。 复制代码代码如下: SQL> select name from v$datafile; NAME -------------------------------------------------------------------------------- /app/oracle/oradata/ORCL/datafile/o1_mf_system_wqbnk_.dbf /app/oracle/oradata/ORCL/datafile/o1_mf_undotbs1_wqxgl_.dbf /app/oracle/oradata/ORCL/datafile/o1_mf_sysaux_wr5p6_.dbf /app/oracle/oradata/ORCL/datafile/o1_mf_users_wrj4o_.dbf SQL> host rm /app/oracle/oradata/ORCL/datafile/o1_mf_users_wrj4o_.dbf 2. 尝试在users表空间中创建表,开始报错。 复制代码代码如下: SQL> create table t tablespace users as select * from dual; create table t tablespace users as select * from dual * ERROR at line 1: ORA-: error in opening database file 4 ORA-: data file 4: '/app/oracle/oradata/ORCL/datafile/o1_mf_users_wrj4o_.dbf' ORA-: unable to open file Linux Error: 2: No such file or directory Additional information: 3 在告警日志中,同样也可以看到类似信息。 复制代码代码如下: Mon Dec :: CST Errors in file /app/oracle/admin/orcl/bdump/orcl_m_.trc: ORA-: error in opening database file 4 ORA-: data file 4: '/app/oracle/oradata/ORCL/datafile/o1_mf_users_wrj4o_.dbf' ORA-: unable to open file Linux Error: 2: No such file or directory Additional information: 3 3. 检查dbwr的进程PID 复制代码代码如下: $ ps -ef|grep dbw0|grep -v grep oracle 1 0 : ? :: ora_dbw0_orcl 4. dbwr会打开所有数据文件的句柄。在proc目录中可以查到,目录名是进程PID,fd表示文件描述符。 复制代码代码如下: $ cd /proc//fd $ ls -l total 0 lr-x------ 1 oracle dba Dec : 0 -> /dev/null lr-x------ 1 oracle dba Dec : 1 -> /dev/null lr-x------ 1 oracle dba Dec : -> /dev/zero lr-x------ 1 oracle dba Dec : -> /dev/zero lr-x------ 1 oracle dba Dec : -> /app/oracle/product/.2.0/db_1/rdbms/mesg/oraus.msb lrwx------ 1 oracle dba Dec : -> /app/oracle/product/.2.0/db_1/dbs/hc_orcl.dat lrwx------ 1 oracle dba Dec : -> /app/oracle/product/.2.0/db_1/dbs/lkORCL lrwx------ 1 oracle dba Dec : -> /app/oracle/oradata/ORCL/controlfile/o1_mf_wq3ng_.ctl lrwx------ 1 oracle dba Dec : -> /app/oracle/oradata/ORCL/datafile/o1_mf_system_wqbnk_.dbf lrwx------ 1 oracle dba Dec : -> /app/oracle/oradata/ORCL/datafile/o1_mf_undotbs1_wqxgl_.dbf lrwx------ 1 oracle dba Dec : -> /app/oracle/oradata/ORCL/datafile/o1_mf_sysaux_wr5p6_.dbf lrwx------ 1 oracle dba Dec : -> /app/oracle/oradata/ORCL/datafile/o1_mf_users_wrj4o_.dbf (deleted) lr-x------ 1 oracle dba Dec : 2 -> /dev/null lrwx------ 1 oracle dba Dec : -> /app/oracle/oradata/ORCL/datafile/o1_mf_temp_wrbnz_.tmp lr-x------ 1 oracle dba Dec : -> /app/oracle/product/.2.0/db_1/rdbms/mesg/oraus.msb lr-x------ 1 oracle dba Dec : 3 -> /dev/null lr-x------ 1 oracle dba Dec : 4 -> /dev/null l-wx------ 1 oracle dba Dec : 5 -> /app/oracle/admin/orcl/udump/orcl_ora_.trc l-wx------ 1 oracle dba Dec : 6 -> /app/oracle/admin/orcl/bdump/alert_orcl.log lrwx------ 1 oracle dba Dec : 7 -> /app/oracle/product/.2.0/db_1/dbs/lkinstorcl (deleted) l-wx------ 1 oracle dba Dec : 8 -> /app/oracle/admin/orcl/bdump/alert_orcl.log lrwx------ 1 oracle dba Dec : 9 -> /app/oracle/product/.2.0/db_1/dbs/hc_orcl.dat 注意其中"/app/oracle/oradata/ORCL/datafile/o1_mf_users_wrj4o_.dbf (deleted)"字样,表示该文件已经被删除,如果是Solaris操作系统,ls命令不会有如此清晰的显示,为了在Solaris系统中确认哪个句柄对应哪个文件,则需要使用lsof程序。 5. 直接cp该句柄文件名回原位置。 复制代码代码如下: cp /app/oracle/oradata/ORCL/datafile/o1_mf_users_wrj4o_.dbf 6. 进行数据文件recover 复制代码代码如下: SQL> alter database datafile 4 offline; Database altered. SQL> recover datafile 4; Media recovery complete. SQL> alter database datafile 4 online; Database altered. 完成数据文件恢复。 恢复的原理是,在Linux操作系统中,如果文件从操作系统级别被rm掉,之前打开该文件的进程仍然持有相应的文件句柄,所指向的文件仍然可以读写,并且该文件的文件描述符可以从/proc目录中获得。但是要注意的是,此时如果关闭数据库,则此句柄会消失,那么除了扫描磁盘进行文件恢复之外就没有其它方法了,因此在数据库出现问题的时候,如果不确认情况的复杂程度,千万不要随便关闭数据库。重启数据库往往是没有意义的,甚至是致命的。 当然,客户的操作系统是Solaris,并且客户删除的文件还包括current online redo log,因此还有其它更复杂的操作,不在这里描述。

推荐整理分享Linux(Unix)中误删除的文件恢复方法(linux误删文件怎么办),希望有所帮助,仅作参考,欢迎阅读内容。

Linux(Unix)中误删除的文件恢复方法(linux误删文件怎么办)

文章相关热门搜索词:linux误删文件恢复,linux误删文件恢复,linux误删除文件,linux不小心删除文件,linux误删除文件,linux中误删了文件怎么恢复,linux误删除文件,linux误删除怎么找回,内容如对您有帮助,希望把文章链接给更多的朋友!

Linux中误删除数据文件和归档日志的恢复方法 误删除前,归档日志2个,用户数据条复制代码代码如下:[oracle@stationdatafile]$sqlplus/nologSQLconnhr/hrConnected.SQLhostls-l/u/app/oracle/flash_recovery_area/ORCL/archi

安装linux时遇到GPT分区表问题的解决方法 一、如果之前服务器上安装过Windows、VMware、MacOS,那么安装linux时,可能会遇到您的boot分区使用的是GPT分区表,但是这台机器不支持使用GPT启动的问题

linux系统中scp命令的使用介绍 scp命令的用处:scp在网络上不同的主机之间复制文件,它使用ssh安全协议传输数据,具有和ssh一样的验证机制,从而安全的远程拷贝文件。scp命令基本

标签: linux误删文件怎么办

本文链接地址:https://www.jiuchutong.com/biancheng/362092.html 转载请保留说明!

上一篇:史上最详细的mrtg(Multi Router Traffic Grapher)设置说明

下一篇:Linux中误删除数据文件和归档日志的恢复方法(linux误删除数据)

  • 海关关税计算公式
  • 个人所得税综合税率表2023
  • 汇算清缴企业所得税弥补亏损明细表怎么填
  • 无票收入需要缴纳所得税吗
  • 工资不纳税项目
  • 没有数字的公章有效吗三方协议盖的章没有数字
  • 服装公司的吊牌是什么
  • 应交税费负数调整
  • 长期负债平均余额怎么算
  • 保险没有合同能退保吗
  • 固定资产期初余额在哪里录入
  • 冲销去年暂估费用
  • 土地出让金抵减销项税如何申报
  • 自产产品销售增值税
  • 私车公用保险费用公司承担吗
  • 免税和不免税的价格区别
  • 个人股权转让申报表
  • 冲红发票开具
  • 非银行支付机构条例(征求意见稿)
  • 长期待摊费用无发票怎么处理
  • 工会发放慰问品总金额超过多少需要比价
  • 买一赠一商品必须一样吗
  • 施工企业工作流程
  • 企业购入土地如何处理
  • 申报表利润总额与财务报表利润总额
  • 跨年暂估成本的账务处理冲回
  • 开发票有时间限制吗?
  • 在win7中,如何搜索指定扩展名的文件
  • php日期时间函数
  • 支付给代理机构的手续费计入
  • php中imagecreatefromjpeg
  • php怎么发布
  • 定额征收的个体户怎么做账
  • 资产负债表中各项目的期末余额
  • 结转已销售产品成本20000元
  • 报废汽车残值收入如何计税
  • php递归实现1到100的和
  • php16进制
  • php 集成环境
  • php备份mysql数据库
  • 加计抵减现代服务税率
  • php扫一扫识别代码
  • Attentional Feature Fusion 注意力特征融合
  • 国企无偿划转股权免印花税
  • 各行业税点大全最新
  • 内部交易费用外部交易费用
  • 商业折扣影响销售成本吗
  • 差旅费可以抵扣嘛
  • 应收账款是指什么
  • 国际货运代理免增值税
  • 未抵扣进项税额什么意思
  • 印花税如何计算缴纳
  • 收到预付卡的发票是否可以报销呢?
  • 公司前期装修费属于开办费吗
  • 期初数不对怎么办
  • 租户押金抵房租
  • 收回理财款会计分录
  • 单利率和复利率公式
  • 装修公司完工交付文案
  • 财产裁定书
  • 企业所得税季报营业成本包括哪些
  • 工业企业应通过其他应付款科目核算的有
  • 货币资金核算内容
  • sqlserver怎么用
  • mysql 索引的类型
  • MySQL 5.7.18 release版安装指南(含有bin文件版本)
  • Win7 64位旗舰版系统打开应用程序提示“发生未知的软件异常0xc06d007e”的解决方法
  • mac系统操作的小技巧
  • eac.exe是什么
  • windows8.1玩英雄联盟
  • windows7如何关闭update
  • vs2012怎么样
  • opengl导入obj
  • opencv for python
  • js过滤filter
  • 重庆电子税务局app下载
  • 金米财税口碑如何?
  • 广东佛山超市排名
  • 纳税申报期限和税款缴纳期限一样吗
  • 车辆过户给自己家人
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设