Oracle数据库添加和移动控制文件

配置Oracle数据库控制文件冗余的操作过程:
查看数据字典v$controlfile来获取现有控制文件信息
  1. SQL> set lines 200;
  2. SQL> col name for a50;
  3. SQL> select * from v$controlfile;

  4. STATUS    NAME             IS_ BLOCK_SIZE FILE_SIZE_BLKS
  5. ------- ------------------------------ --- ---------- --------------
  6.     /data/cams/control01.ctl NO    16384         692
  7.     /data/cams/control02.ctl NO    16384         692

此处发现两个控制文件在一个路径下,显然不安全,现在对控制文件做冗余

查看spfile信息:

  1. SQL> show parameter pfile;

  2. NAME                 TYPE     VALUE
  3. ------------------------------------ ----------- ------------------------------
  4. spfile                 string     /oradata/oracle/product/11.2.0
  5.                                  /db_1/dbs/spfilecams.ora

关闭数据库,创建pfile文件

  1. SQL> create pfile from spfile;
  2. SQL> !ls /oradata/oracle/product/11.2.0/db_1/dbs
  3. hc_cams.dat initcams.ora init.ora lkCAMS orapwcams    snapcf_cams.f spfilecams.ora
  4. SQL> !vi /oradata/oracle/product/11.2.0/db_1/dbs/initcams.ora

  5. 修改*.control_files='/data/cams/control01.ctl','/data/cams/control02.ctl'内容为
  6. *.control_files='/data/cams/control01.ctl','/file/cams/controlfile/control02.ctl','/backup/cams/controlfile/control03.ctl'

创建路径

  1. mkdir -p /file/cams/controlfile
  2. mkdir -p /backup/cams/controlfile

拷贝现有控制文件至存储路径中

  1. SQL> !ls /file/cams/controlfile
  2. control02.ctl

  3. SQL> !ls /backup/cams/controlfile
  4. control03.ctl

通过pfile启动oracle,并新创建spfile

  1. SQL> startup pfile='/oradata/oracle/product/11.2.0/db_1/dbs/initcams.ora';
  2. SQL> create spfile from pfile;
  3. SQL> shutdown immediate;
  4. SQL> startup;

总结操作过程:
(1)利用数据字典v$controlfile来获取现有控制文件信息。

(2)查看spfile所在路径

(3)正常关闭数据库
(4)利用spfile文件创建pfile文件
(5)修改pfile文件中的CONTROL_FILES参数,修改为最新的控制文件信息
(6)创建新的文件路径,并将现有控制文件拷贝到指定位置
(7)通过pfile启动oracle,并新创建spfile
(8)关闭数据库,利用spfile参数文件启动数据库


其他说明:
(1)如果数据库使用pfile启动,没有spfile,可以省略spfile和pfile切换过程,直接修改pfile即可。
(2)本文操作也可不使用spfile转化为pfile后进行修改的操作,使用alter system set control_files = XXX scope=spfile;命令实现改变CONTROL_FILES参数信息。
(3)修改完成后建议进行检查,查看v$controlfile以及服务器上的物理控制文件。
(4)如果操作完成后出现无用控制文件,比如用不到原控制文件了,建议在操作完成后删除无用的控制文件,避免出现系统垃圾文件。