DBF 文件 ORACLE 数据库恢复

清·魏源《庸易通义》:“至道问学之有知无行,分温故为存心,知新为致知,而敦厚为存心,崇礼为致知,此皆百密一疏。”

起因

在我们的生产活动中,意外总是在不经意间发生。那天一个安装有 oracle 数据库的盘符不小心被格式化了,好几个项目都炸了。不过还好有备份,不过只有 .DBF 文件和几个日志文件:

//数据库系统相关
REDO01.LOG
REDO02.LOG
REDO03.LOG SYSTEM01.DBF
UNDOTBS01.DBF
SYSAUX01.DBF
USERS01.DBF //项目相关
xxx.DBF

解决

前期准备

  1. 重新安装和之前一样的数据库版本、实例名都和之前的一致;
  2. 编写创建控制文件 CONTROLFILE 的命令。

控制文件(Control File)是Oracle的物理文件之一,它记录了数据库的名字、数据文件的位置等信息。控制文件的重要性在于,一旦控制文件损坏,数据库将会宕机。如果没有数据库的备份和归档日志文件,数据库将无法恢复。因此,我们应该多路镜像控制文件(Multiplex Control Files),并把每个镜像的控制文件分布在不同的物理磁盘。根据经验,控制文件多路镜像以后,几个控制文件同时坏掉的可能性几乎为零。控制文件管理的重心是重在预防,而不是亡羊补牢!

控制文件实例:

CREATE CONTROLFILE REUSE DATABASE "数据库名(orcl)" NORESETLOGS  ARCHIVELOG
MAXLOGFILES 16
MAXLOGMEMBERS 3
MAXDATAFILES 100
MAXINSTANCES 8
MAXLOGHISTORY 454
LOGFILE
GROUP 1 '需要恢复的日志文件路径(E:\oradata\orcl\)REDO01.LOG' SIZE 50M,
GROUP 2 '同上\REDO02.LOG' SIZE 50M,
GROUP 3 '同上\REDO03.LOG' SIZE 50M
DATAFILE(数据文件)
-- 系统相关
'需要恢复的数据文件路径(E:\oradata\orcl\)SYSTEM01.DBF',
'需要恢复的数据文件路径(E:\oradata\orcl\)UNDOTBS01.DBF',
'需要恢复的数据文件路径(E:\oradata\orcl\)SYSAUX01.DBF',
'需要恢复的数据文件路径(E:\oradata\orcl\)USERS01.DBF',
-- 用户数据相关
'需要恢复的数据文件路径(E:\oradata\orcl\)TEST01.DBF',
'需要恢复的数据文件路径(E:\oradata\orcl\)TEST02.DBF'
'CHARACTER SET ZHS16GBK;

操作步骤

1.进入 cmd 输入命令:

sqlplus

然后以数据库管理员身份登录系统,输入:

sys / as sysdba

输入命令回车,下一步输入密码即可进入到数据库命令行模式。

2.备份控制文件到 trace 文件,输入命令:

alter database backup controlfile to trace;

3.停止数据库,输入命令:

shutdown immediate;

4.以 nomount 状态启动数据库,输入命令:

startup nomount;

5.执行创建控制文件的命令,输入前期准备好的创建控制文件的命令:

6.恢复数据库,输入命令:

recover database;

7.将数据库从 mount 状态切换到 open 状态,这时就是使用数据库了,输入命令:

alter database open;

oracle数据库启动分三个步骤 nomount mount open startup是数据库从开始阶段的启动du,需要经过上述zhi三个步dao骤 alter database open是数据库处于mount状态,从mount状态打开数据库的命令

至此,dbf 文件恢复 oracle 数据库就完成了。祝君好运!

期间遇到的问题

有问题不要害怕,一个一个去解决它,从中汲取养料,相信自己。

问题一

数据库恢复成功后,连接数据库遇到

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aNrFPOfC-1609941209785)(https://cdn.jsdelivr.net/gh/filess/img10@main/2021/01/06/1609939139070-3baeea76-c41a-48f7-b36b-fb1c3f3f6ce0.png)]

因为归档文件的空间满了。

解决一

增加归档日志空间或者删除归档日志(谨慎操作),可同时操作。

1.增加归档日志空间:

//查看当前归档空间大小
select * from v$recovery_file_dest;
//相应增加归档日志空间大小
alter system set db_recovery_file_dest_size=20G scope=both;

2.删除归档日志

//重新打开一个 cmd 窗口,输入命令:进入 rman
rman target /
//删除所有的归档日志
delete archivelog all;

问题二

ORA-00379: no free buffers available in buffer pool DEFAULT for block size 16K

缓冲池 DEFAULT 中无法提供 16K 块大小的空闲缓冲区

解决二

  1. 查看 16K 块大小
show parameter db_16k_cache_size

2.设置 16K 块缓冲区大小

alter system set db_16k_cache_size=10m;

问题三

ORA-12516

ORA-12516: TNS: 监听程序找不到符合协议堆栈要求的可用处理程'

解决三

1.查看数据库现有的进程(process)数是否已经达到参数 processes 的大小;当前会话数量(session)是否达到参数 sessions 的大小。

//获取当前数据库所有的进程数量
select count(*) from v$process;
//获取当前数据库所有会话数量
select count(*) from v$session;
//获取 processes 大小
show parameter processes;
//获取 sessions 大小
show parameter sessions

2.修改 processes 值和 sessions 值

alter system set processes=300 scope=spfile;
alter system set sessions=335 scope=spfile;

3.重启数据库生效

shutdown immediate; or shutdown
startup

公众号“手机APP软件知识分享库”,原创文章第一时间推送。

DBF 文件 ORACLE 数据库恢复的更多相关文章

  1. oracle数据库恢复与备份

    一.oracle数据库恢复 1.恢复刚才删除的一条数据 delete from emp e where e.empname='SMITH' select * from flashback_transa ...

  2. 重装系统后ORACLE数据库恢复的方法

    如果我们的操作系统出现问题,重装系统后,ORACLE数据库应该如何恢复呢?下文就为您列举了两个重装系统后ORACLE数据库恢复的方法,供您参考. ORACLE数据库恢复的方法我们经常会用到,下面就为您 ...

  3. 把oracle数据库恢复到某个时间点或者某个scn

    alter session set nls_date_format='yyyymmdd hh24:mi:ss'; select sysdate from dual; conn dbauser/1234 ...

  4. Raid信息丢失数据恢复及oracle数据库恢复验证方案

    早些时候,有个客户14块盘的磁盘阵列出现故障,需要恢复的数据是oracle数据库,客户在寻求数据恢复技术支持,要求我提供详细的数据恢复方案,以下是提供给客户的详细数据恢复解决方案,本方案包含Raid数 ...

  5. Oracle 数据库恢复命令

    前提是oracle服务能正常启动,但是客户端怎么都连接不上. 首先打开命令行,输入:sqlplus / as sysdba; 回车 连上数据库后,屏幕会显示:已连接到空闲例程. 接下来在SQL> ...

  6. Oracle数据库恢复

    建用户 wf2014 赋权限 grant dba to wf2014; 数据恢复 imp wf2014/wf2014 file=D:\wf2014.dmp full=y 参数设置: datasourc ...

  7. oracle数据库恢复归档脚本

    cat restorearch1.sh rman target / << EOFRUN {SET ARCHIVELOG DESTINATION TO '/archlog1/db2_arch ...

  8. undo丢失恢复异常恢复,运维DBA反映Oracle数据库无法启动报错ORA-01157 ORA-01110,分析原因为Oracle数据库坏块导致

    本文转自 惜纷飞 大师. 模拟基表事务未提交数据库crash,undo丢失恢复异常恢复,运维DBA反映Oracle数据库无法启动报错ORA-01157 ORA-01110,分析原因为Oracle数据库 ...

  9. 在oracle下我们如何正确的执行数据库恢复

    标签:oracle 数据库 恢复 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://jiujian.blog.51cto.com/4 ...

随机推荐

  1. 第14.6节 使用Python urllib.request模拟浏览器访问网页的实现代码

    Python要访问一个网页并读取网页内容非常简单,在利用<第14.5节 利用浏览器获取的http信息构造Python网页访问的http请求头>的方法构建了请求http报文的请求头情况下,使 ...

  2. 问题: 刚安装的PyCharm执行代码报“ModuleNotFoundError: No module named XXXX”错

    老猿刚安装好PyCharm后,直接新建了一个工程文件并导入了一个已有的爬虫程序文件,该文件原来在Python解释器下能执行,但在PyCharm下执行时报错: F:\学习\python\SRC\proj ...

  3. 关于将Linux中默认的OpenJDK替换为JDK的方法

    首先下载需要的jdk安装包,后缀建议.tar.gz,本文中以jdk-8u212-linux-x64.tar.gz为例,地址就在oracle官网. 将安装包下载到linux环境后,使用命令tar -xz ...

  4. C++ 虚函数表与多态 —— 关键字 override 的用法

    override 仅能用于虚函数,他属于C++新特性,是重写覆盖的意思,他的存在仅仅是为了提高代码的可阅读性: 作用: 1. 提示程序的阅读者,这个函数是重写父类的功能. 2. 防止程序员在重写父类的 ...

  5. sqli-labs less-24(二次注入)

    less-24 原理: 在网站处理用户提交的数据的时候,只是将某些敏感字符进行了转义.因而使得用户第一次提交的时候不会被当做代码执行.但是这些数据存入数据库的时候却没有转义,而网站程序默认数据库中的数 ...

  6. 微信小程序api拦截器

    微信小程序api拦截器 完美兼容原生小程序项目 完美兼用小程序api的原本调用方式,无痛迁移 小程序api全Promise化 和axios一样的请求方式 小程序api自定义拦截调用参数和返回结果 强大 ...

  7. 环境篇:Atlas2.1.0兼容CDH6.3.2部署

    环境篇:Atlas2.1.0兼容CDH6.3.2部署 Atlas 是什么? Atlas是一组可扩展和可扩展的核心基础治理服务,使企业能够有效地满足Hadoop中的合规性要求,并允许与整个企业数据生态系 ...

  8. HBase按照TimeStamp删除数据

    #!/bin/bash #两种时间输入,一种是输入起始日期,另一种是直接输入hbase里面数据的起始时间戳 if [ $# != 5 ];then echo 'usage:sh byTimestamp ...

  9. 2020-2021-1 20209307《Linux内核原理与分析》第五周作业

    一.理论知识 系统调用:操作系统为用户态进程与硬件设备进行交互提供的一组接口. 系统调用的三层皮:API(应用程序接口),中断向量system_call,中断服务程序sys_xyz 宏观上Linux操 ...

  10. 多任务-python实现-多线程共享全局变量(2.1.3)

    @ 目录 1.全局变量的修改 2.全局变量在多线程中的共享 3.多线程可能遇到的问题 1.全局变量的修改 代码实现 num = 100 nums = [11,22] def test(): globa ...