Oracle控制文件的移动、添加、损坏故障模拟修复

简介:
oracle数据库中的控制文件是二进制文件,其记录了数据库名、数据库标识符、数据库创建时间、表空间信息、重做日志文件历史、归档日志文件位置和状态信息、日志序列号、检查点、备份状态信息和位置。
oracle初始安装默认会生成3个控制文件(windows下oracle会生成3个,linux下好像是1个);
查找控制文件物理位置
show parameter control_files
Oracle控制文件的移动、添加、损坏故障模拟修复
sql语句:
select  from v$parameter where name='control_files';
那么控制文件是什么时候开始加载呢?
Oracle控制文件的移动、添加、损坏故障模拟修复
控制文件比较重要,建议将控制文件存放在不同的分区,并创建3个以上的控制文件;接下来演示移动控制文件到不同的分区。
oracle 11g默认使用spfile启动数据库,oracle 9i以前都是用pfile启动数据库;这里所说的pfile和spfile就是指参数文件。
查询当前库使用的参数文件启动的数据库
select decode(count(
),1,'spfile','pfile') from v$spparameter where rownum=1 and isspecified = 'TRUE';
移动控制文件之前,先查找当前库的控制文件所在的位置
Oracle控制文件的移动、添加、损坏故障模拟修复
使用以下命令修改spfile文件信息,因为spfile文件无法直接通过操作系统命令修改,但是pfile可以直接修改。
alter system set control_files='/u01/app/oracle/oradata/control01.ctl' scope=spfile;
Oracle控制文件的移动、添加、损坏故障模拟修复
执行完毕后关闭数据库
shutdown immediate;——此步骤很重要,一定要停库再拷贝控制文件
将控制文件通过操作系统命令移动到要修改的目录下,
Oracle控制文件的移动、添加、损坏故障模拟修复
再启动数据库sqlplus / as sysdba
startup
控制文件移动成功
Oracle控制文件的移动、添加、损坏故障模拟修复
接下来演示下如何添加控制文件
alter system set control_files='/u01/app/oracle/oradata/control01.ctl','/u01/app/oracle/oradata/orcl/control02.ctl' scope=spfile;
Oracle控制文件的移动、添加、损坏故障模拟修复
关闭数据库——此步骤很重要,一定要停库再拷贝控制文件
复制原有的一个控制文件到制定的目录
Oracle控制文件的移动、添加、损坏故障模拟修复
startup 启动数据库
Oracle控制文件的移动、添加、损坏故障模拟修复
查看数据库是否正常
Oracle控制文件的移动、添加、损坏故障模拟修复
接下来模拟一个控制文件损坏如何修复;
删除一个控制文件
Oracle控制文件的移动、添加、损坏故障模拟修复
删除控制文件后,无法shutdown了
Oracle控制文件的移动、添加、损坏故障模拟修复
强制关闭数据库
shutdown abort
复制一个可以使用的控制文件到损坏的控制文件目录
Oracle控制文件的移动、添加、损坏故障模拟修复
启动数据库
Oracle控制文件的移动、添加、损坏故障模拟修复
如果控制文件全部都损坏了。需要进行控制文件备份,但是控制文件会时刻发生变化。后期菜鸡哥哥再持续研究如何持续保证控制文件的完整性,当然如果你的控制文件分别放在不同的分区,也全部挂掉,那么你可以去买彩票了!!!









本文转自 rm_rf_db 51CTO博客,原文链接:http://blog.51cto.com/12185273/2054123,如需转载请自行联系原作者
目录
相关文章
|
14天前
|
SQL Oracle 关系型数据库
【赵渝强老师】Oracle的控制文件与归档日志文件
本文介绍了Oracle数据库中的控制文件和归档日志文件。控制文件记录了数据库的物理结构信息,如数据库名、数据文件和联机日志文件的位置等。为了保护数据库,通常会进行控制文件的多路复用。归档日志文件是联机重做日志文件的副本,用于记录数据库的变更历史。文章还提供了相关SQL语句,帮助查看和设置数据库的日志模式。
【赵渝强老师】Oracle的控制文件与归档日志文件
|
14天前
|
Oracle 关系型数据库 数据库
【赵渝强老师】Oracle的参数文件与告警日志文件
本文介绍了Oracle数据库的参数文件和告警日志文件。参数文件分为初始化参数文件(PFile)和服务器端参数文件(SPFile),在数据库启动时读取并分配资源。告警日志文件记录了数据库的重要活动、错误和警告信息,帮助诊断问题。文中还提供了相关视频讲解和示例代码。
|
1月前
|
存储 Oracle 关系型数据库
数据库数据恢复—Oracle ASM磁盘组故障数据恢复案例
Oracle数据库数据恢复环境&故障: Oracle ASM磁盘组由4块磁盘组成。Oracle ASM磁盘组掉线 ,ASM实例不能mount。 Oracle数据库故障分析&恢复方案: 数据库数据恢复工程师对组成ASM磁盘组的磁盘进行分析。对ASM元数据进行分析发现ASM存储元数据损坏,导致磁盘组无法挂载。
|
14天前
|
SQL Oracle 关系型数据库
【赵渝强老师】Oracle的数据文件
在Oracle数据库中,数据库由多个表空间组成,每个表空间包含多个数据文件。数据文件存储实际的数据库数据。查询时,如果内存中没有所需数据,Oracle会从数据文件中读取并加载到内存。可通过SQL语句查看和管理数据文件。附有视频讲解及示例。
|
2月前
|
Oracle 关系型数据库 数据库
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
打开oracle数据库报错“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。 数据库没有备份,无法通过备份去恢复数据库。用户方联系北亚企安数据恢复中心并提供Oracle_Home目录中的所有文件,急需恢复zxfg用户下的数据。 出现“system01.dbf需要更多的恢复来保持一致性”这个报错的原因可能是控制文件损坏、数据文件损坏,数据文件与控制文件的SCN不一致等。数据库恢复工程师对数据库文件进一步检测、分析后,发现sysaux01.dbf文件损坏,有坏块。 修复并启动数据库后仍然有许多查询报错,export和data pump工具使用报错。从数据库层面无法修复数据库。
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
|
1月前
|
Oracle 关系型数据库 数据库
oracle数据恢复—Oracle数据库文件损坏导致数据库打不开的数据恢复案例
打开oracle数据库时报错,报错信息:“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。急需恢复zxfg用户下的数据。 出现上述报错的原因有:控制文件损坏、数据文件损坏、数据文件与控制文件的SCN不一致等。数据恢复工程师对数据库文件做进一步检测分析后发现sysaux01.dbf文件有坏块。修复sysaux01.dbf文件,启动数据库依然有许多查询报错。export和data pump工具无法使用,查询告警日志并分析报错,确认发生上述错误的原因就是sysaux01.dbf文件损坏。由于该文件损坏,从数据库层面无法修复数据库。由于system和用户表空间的数据文件是正常的,
|
4月前
|
Oracle 关系型数据库 数据库
关系型数据库Oracle 故障转移能力
【7月更文挑战第10天】
62 2
|
5月前
|
SQL Oracle 关系型数据库
mysql和oracle 命令行执行sql文件 数据库执行sql文件 执行sql语句
mysql和oracle 命令行执行sql文件 数据库执行sql文件 执行sql语句
76 0
|
Oracle 关系型数据库 Linux
Oracle 数据文件 reuse 属性 说明
有关表空间创建的相关参数,参考: Oracle 表空间 创建参数 说明 http://blog.csdn.net/tianlesoftware/archive/2011/01/27/6166928.aspx 当我们对表空间添加数据文件的时候,有一个reuse 属性。
862 0