探索ORACLE之RMAN_07控制文件丢失恢复

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 探索ORACLE之RMAN_07控制文件丢失恢复 作者:吴伟龙   Name:Prodence Woo QQ:286507175  msn:hapy-wuweilong@hotmail.com 1、     控制文件(controlfile)丢失恢复 基于控制文件的复合多路径性,它的丢失分为两种,一种是其中某个控制文件的损坏或丢失,另外一种是所有控制文件均丢失。

探索ORACLERMAN_07控制文件丢失恢复

作者:吴伟龙   NameProdence Woo

QQ286507175  msn:hapy-wuweilong@hotmail.com

1、     控制文件(controlfile)丢失恢复

基于控制文件的复合多路径性,它的丢失分为两种,一种是其中某个控制文件的损坏或丢失,另外一种是所有控制文件均丢失。基于第一种情况,只需把好的控制文件复制一份在损坏或丢失的那个控制文件路径下即可。第二种情况下则需要通过备份信息来对控制文件进行恢复或手工重建控制文件。

丢失单一控制文件的判断及恢复。

数据库无法正常关闭,因为在关闭的时候必须向控制文件中更新scn

SQL>shutdown immediate

ORA-00210:cannot open the specified control file

ORA-00202:control file: '/DBData/oradata/WWL/control02.ctl'

ORA-27041:unable to open file

LinuxError: 2: No such file or directory

Additionalinformation: 3

 

必须强制关闭数据库

SQL>shutdown abort;

ORACLEinstance shut down.

 

启动数据库报控制文件验证失败,检查告警日志文件

SQL>startup

ORACLEinstance started.

 

TotalSystem Global Area  285212672 bytes

FixedSize                  1218968 bytes

VariableSize             104859240 bytes

DatabaseBuffers          171966464 bytes

RedoBuffers                7168000 bytes

ORA-00205:error in identifying control file, check alert log for more info

 

查看告警日志,报提示找不到controlfile2

Fri Jun 2211:54:26 2012

Errors infile /DBSoft/admin/WWL/udump/wwl_ora_4816.trc:

ORA-00210:cannot open the specified control file

ORA-00202:control file: '/DBData/oradata/WWL/control02.ctl'

ORA-27041:unable to open file

LinuxError: 2: No such file or directory

 

从上面的信息我们可以得出是由于控制文件丢失导致了数据库无法正常的启动和关闭,下面我们要做的就是对控制文件进行做恢复,因为我们知道控制文件具有重复多路径属性,默认会有三个控制文件。现在日志中看到的是控制文件2丢失,找不到,我们可以通过控制文件13来恢复2

4.1 基于正常控制文件恢复损坏的控制文件

   1、查看控制文件存在路径

SQL>show parameter control_files

 

NAME          TYPE       VALUE

----------------------------------------------- ------------------------------

control_files     string      /DBSoft/oradata/WWL/control01.ctl,/DBData/oradata/WWL/control02.ctl, /DBData/oradata/WWL/control03.ctl

SQL>

    我们可以从如上看到,该套数据库存在三个控制文件其中一个控制文件存放在/DBSoft目中中的oradata/wwl/目录下,另外两个控制文件存在/DBData目录中的/oradata/wwl/的目录下,从上面刚才的信息中我们可以得之是control02.ctl控制文件丢失导致数据库故障。

   2、检查下控制文件是不存在还是损坏了

[oracle@wwldb WWL]$cd /DBData/oradata/WWL/

[oracle@wwldb WWL]$ll

total 0

[oracle@wwldb WWL]$

 

怪了,这个目录怎么一个控制文件都没有了呀,看看控制文件一是否存在。

[oracle@wwldb WWL]$ cd/DBSoft/oradata/WWL/

[oracle@wwldb WWL]$ ls

control01.ctl

 

非常万幸,controlfile1还是存在的,这样我们就可以通过controlfile1来恢复controlfile23了。

   3、关闭数据库

SQL> shutdown abort

ORACLE instance shut down.

SQL>

 

4、恢复损坏丢失的控制文件

[oracle@wwldbWWL]$ ls

control01.ctl

[oracle@wwldbWWL]$ pwd

/DBSoft/oradata/WWL

[oracle@wwldbWWL]$ ls

control01.ctl

[oracle@wwldbWWL]$ cp control01.ctl /DBData/oradata/WWL/control02.ctl

[oracle@wwldbWWL]$ cp control01.ctl /DBData/oradata/WWL/control03.ctl

[oracle@wwldbWWL]$ ll /DBData/oradata/WWL/

total13792

-rw-r-----1 oracle oinstall 7061504 Jun 22 12:51 control02.ctl

-rw-r-----1 oracle oinstall 7061504 Jun 22 12:51 control03.ctl

[oracle@wwldb WWL]$

2、启动数据库

SQL>startup

ORACLEinstance started.

 

Total SystemGlobal Area 285212672 bytes

FixedSize                 1218968 bytes

VariableSize            104859240 bytes

DatabaseBuffers         171966464 bytes

RedoBuffers               7168000 bytes

Databasemounted.

Databaseopened.

SQL>

 

 

  4.2所有控制文件全部丢失。

      丢失单一控制文件的判断及恢复。

 数据库无法正常关闭,因为在关闭的时候必须向控制文件中更新scn

SQL>shutdown immediate

ORA-00210:cannot open the specified control file

ORA-00202:control file: ' /DBSoft/oradata/WWL/control01.ctl'

ORA-27041:unable to open file

LinuxError: 2: No such file or directory

Additionalinformation: 3

 

必须强制关闭数据库

SQL>shutdown abort;

ORACLEinstance shut down.

 

启动数据库报控制文件验证失败,检查告警日志文件

SQL>startup

ORACLEinstance started.

 

TotalSystem Global Area  285212672 bytes

FixedSize                  1218968 bytes

VariableSize             104859240 bytes

DatabaseBuffers          171966464 bytes

RedoBuffers                7168000 bytes

ORA-00205:error in identifying control file, check alert log for more info

 

查看告警日志,报提示找不到controlfile1

Fri Jun 22 13:16:07 2012

Errors in file /DBSoft/admin/WWL/udump/wwl_ora_5104.trc:

ORA-00210: cannot open the specified control file

ORA-00202: control file: '/DBSoft/oradata/WWL/control01.ctl'

ORA-27041: unable to open file

Linux Error: 2: No such file or directory

Additional information: 3

 

通过RMAN来进行控制文件的恢复:

1、强制启动数据库到nomount状态

SQL> startupforce nomount;

ORACLE instancestarted.

 

Total SystemGlobal Area  285212672 bytes

Fixed Size                  1218968 bytes

VariableSize             109053544 bytes

Database Buffers          167772160 bytes

RedoBuffers                7168000 bytes

SQL> exit

2、执行restore控制文件恢复

RMAN>restore controlfile;

 

3、打开数据库

SQL>alter database mount;

Database altered.

 

SQL>alter database open;

Database altered.

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
4月前
|
SQL Oracle 关系型数据库
【赵渝强老师】Oracle的控制文件与归档日志文件
本文介绍了Oracle数据库中的控制文件和归档日志文件。控制文件记录了数据库的物理结构信息,如数据库名、数据文件和联机日志文件的位置等。为了保护数据库,通常会进行控制文件的多路复用。归档日志文件是联机重做日志文件的副本,用于记录数据库的变更历史。文章还提供了相关SQL语句,帮助查看和设置数据库的日志模式。
140 1
【赵渝强老师】Oracle的控制文件与归档日志文件
|
4月前
|
SQL Oracle 关系型数据库
Oracle 从 DMP 文件中恢复指定表的步骤
Oracle 从 DMP 文件中恢复指定表的步骤
293 7
|
4月前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—Oracle数据库文件有坏快损坏的数据恢复案例
一台Oracle数据库打开报错,报错信息: “system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。管理员联系我们数据恢复中心寻求帮助,并提供了Oracle_Home目录的所有文件。用户方要求恢复zxfg用户下的数据。 由于数据库没有备份,无法通过备份去恢复数据库。
|
4月前
|
Oracle 关系型数据库 数据库
【赵渝强老师】Oracle的参数文件与告警日志文件
本文介绍了Oracle数据库的参数文件和告警日志文件。参数文件分为初始化参数文件(PFile)和服务器端参数文件(SPFile),在数据库启动时读取并分配资源。告警日志文件记录了数据库的重要活动、错误和警告信息,帮助诊断问题。文中还提供了相关视频讲解和示例代码。
128 1
|
6月前
|
Oracle 关系型数据库 数据库
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
打开oracle数据库报错“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。 数据库没有备份,无法通过备份去恢复数据库。用户方联系北亚企安数据恢复中心并提供Oracle_Home目录中的所有文件,急需恢复zxfg用户下的数据。 出现“system01.dbf需要更多的恢复来保持一致性”这个报错的原因可能是控制文件损坏、数据文件损坏,数据文件与控制文件的SCN不一致等。数据库恢复工程师对数据库文件进一步检测、分析后,发现sysaux01.dbf文件损坏,有坏块。 修复并启动数据库后仍然有许多查询报错,export和data pump工具使用报错。从数据库层面无法修复数据库。
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
|
4月前
|
SQL Oracle 关系型数据库
【赵渝强老师】Oracle的数据文件
在Oracle数据库中,数据库由多个表空间组成,每个表空间包含多个数据文件。数据文件存储实际的数据库数据。查询时,如果内存中没有所需数据,Oracle会从数据文件中读取并加载到内存。可通过SQL语句查看和管理数据文件。附有视频讲解及示例。
|
5月前
|
Oracle 关系型数据库 数据库
oracle数据恢复—Oracle数据库文件损坏导致数据库打不开的数据恢复案例
打开oracle数据库时报错,报错信息:“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。急需恢复zxfg用户下的数据。 出现上述报错的原因有:控制文件损坏、数据文件损坏、数据文件与控制文件的SCN不一致等。数据恢复工程师对数据库文件做进一步检测分析后发现sysaux01.dbf文件有坏块。修复sysaux01.dbf文件,启动数据库依然有许多查询报错。export和data pump工具无法使用,查询告警日志并分析报错,确认发生上述错误的原因就是sysaux01.dbf文件损坏。由于该文件损坏,从数据库层面无法修复数据库。由于system和用户表空间的数据文件是正常的,
|
9月前
|
SQL Oracle 关系型数据库
mysql和oracle 命令行执行sql文件 数据库执行sql文件 执行sql语句
mysql和oracle 命令行执行sql文件 数据库执行sql文件 执行sql语句
117 0
|
9月前
|
存储 SQL Oracle
oracle 存储过程导出sql语句 导出为文件
oracle 存储过程导出sql语句 导出为文件
215 0
|
10月前
|
运维 Oracle 关系型数据库
Oracle日志文件:数据王国的“记事本”
【4月更文挑战第19天】Oracle日志文件是数据库稳定运行的关键,记录数据变更历史,用于恢复和故障处理。它们协调并发操作,确保数据一致性和完整性。日志文件实时写入操作信息并定期刷新到磁盘,便于数据恢复。然而,日志文件需备份和归档以保证安全性,防止数据丢失。日志文件,数据王国的“记事本”,默默守护数据安全。

热门文章

最新文章

推荐镜像

更多