控制文件是一个很小的二进制文件(10MB左右),含有数据库结构信息,包括数据文件和日志文件信息。控制文件在数据库创建时被自动创建,并在数据库发生物理变数时更新。控制文件被不断更新,在任何时候都要保证控制文件可用,否则数据库将无法启动或者使用。
1 控制文件包含的主要信息如下:
数据库名称和SID标识;
数据文件和日志文件列表;
数据库创建的时间戳;
表空间信息;
当前重做日志文件序列号;
归档日志信息;
检查点信息;
回滚段的起始与结束;
备份数据文件信息;
控制文件包含了如此多的重要信息,需要保护并及时备份控制文件,以便它被损坏或者磁盘介质损货时,能够及时恢复。目前保护控制文件的主要策略为多路复用控制文件与备份控制文件。
2 查看目前系统的控制文件信息,主要是查看相关的字典视图
v$controlfile 包含所有控制文件的名称和状态信息
v$controlfile_record_section 包含控制文件中各个记录文档段的信息
v$parameter 包含了系统所有初始化参数,可以查询到control_files的信息
3 控制文件的多路复用
为了提高数据库的安全性,至少要为数据库建立两个控制文件,而且这两个文件最好分别放在不同的磁盘中,这样可以避免产生由于某个磁盘故障而无法启动数据库的危险,该管理策略称为多路复用控制文件。当多路复用控制文件某个磁盘发生故障导致其包含的控制文件损坏,数据库将被关闭或者发生异常,此时可以用另一磁盘中保存的控制文件来恢复被损坏的控制位文件,然后再重启数据库,达到保护控制文件的目的。
数据库建立时,一般会默认创建两个控制文件,我们可以手动的再创建多个控制文件且不要与默认的放在同一个磁盘中,首先我们可以修改control_files参数来增加控制文件。
3.1 更改CONTROL_FILES
alter system set control_files = ‘/usr/oracle/app/oradata/orcl/control01.ctl‘,‘/usr/oracle/app/flash_recovery_area/orcl/control02.ctl‘,‘/home/oracle/ControlFiles/control03.ctl‘,‘/home/oracle/ControlFiles/control04.ctl‘
scope=spfile;
上面的代码中,前3个控制文件已经创建好,第4个文件是用户将要手动添加的,但是目前还没有创建该文件,创建该文件前需要关闭数据库,然后将第1个复制过去即可;
3.2 复制控制文件
其实添加控制文件就是将之前可用的控制文件复制过去,重命名即可,首先我们需要关闭数据库,然后将/usr/oracle/app/oradata/orcl/control01.ctl 复制为/home/oracle/ControlFiles/control04.ctl即可
复制完之后,再重启数据库,重启之后查询v$control_files;
到此我们控制文件多路复用的操作完成,过程中需要注意的就是,必须先关闭数据库才能把可用的控制文件复制过去,如果没有关闭就复制过去,在重启的时候会报错原控制文件与新增的不一致的错误:
ORA-00214: control file ‘/usr/oracle/app/oradata/orcl/control01.ctl‘ version
7136 inconsistent with file ‘/home/oracle/ControlFiles/control04.ctl‘ version
7133