位置: 编程技术 - 正文

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误删除数据)

  • 税金及附加现金流量表
  • 小规模纳税企业
  • 纳税申报期限是纳税期限期满后的时间
  • 旅游公司的账务框架
  • 个体工商户单位性质怎么填
  • 固定资产中的动态投资包括
  • 个税累计扣除项目合计2712.5是什么
  • 2021年金税盘
  • 公司购买的电脑怎么做账
  • 劳务报酬所得怎么扣税
  • 结转税金需要附件吗
  • 物流企业差额征税
  • 印刷费怎么开发票
  • 专用发票百万元版申请要求
  • 售楼部沙盘制作价格一般多少一平
  • 未开发票申报
  • 哪些发票备注栏必须注明
  • 一次性优惠税率表
  • 企业合并的会计分录
  • 开票金额比收入高怎么办
  • 补交地税多少钱
  • 固定资产可以一次性抵扣进项税吗
  • iphone6s掉水里怎么办
  • 重复确认收入是什么意思
  • php加载
  • 物流公司的收入来源有哪些
  • 公司出租房屋租赁发票税率
  • codewriter怎么运行
  • excel导出exe
  • Thinkphp事务操作实例(推荐)
  • 浅谈如何培养孩子的注意力
  • php用echo输出图片
  • 激光雷达lidar特点
  • 免费开源的图片app
  • 传承古老文化
  • 结构重参数化2d pose
  • checksum 命令
  • php和python结合
  • 小规模纳税人印花税减半征收政策
  • 三方债权债务抵销
  • css 3有哪些新特性
  • 公司财务变更需要变更哪些内容
  • 通用机打发票还能用吗
  • 建筑业先预缴还是先扣税
  • 富文本功能
  • mysql如何打开使用
  • 企业资本包括
  • 新政府会计制度下的基建会计
  • 不含税货款要开发票怎么弄
  • sqlserver表数据导出导入
  • 详解中国女足出线形势
  • sql中循环语句怎么写
  • 金税盘税务申报流程
  • 违约金 专票
  • 手撕定额发票可以抵扣吗
  • 财政直接支付是什么科目
  • 交车辆购置税需要什么材料
  • 企业比赛奖金要交税吗
  • 其他债权投资有哪些科目
  • 银行贷款利息支出税前扣除标准
  • 企业的期间费用包括制造费用吗
  • 金税盘不申报会不会罚款
  • 微信和支付宝的区别
  • 建筑施工企业会计分录大全
  • sql clean
  • centos5.8服务器
  • gwsloader.exe是什么意思
  • dll文件应该放在哪里
  • win8系统运行慢怎么办
  • win10任务栏跳来跳去
  • three.js 文档
  • 查看分区文件格式
  • css在ie失效
  • 安卓开发框架mvvm
  • android 图片滚动
  • 地税局书记是什么级别
  • 自然人电子税务局怎么设置申报密码
  • 巾帼文明岗主题内容
  • 营改增之前和之后
  • 河北地税网上申报纳税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设