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