Oracle控制文件如何高效管理

数据库 Oracle
本文就Oracle控制文件如何高效管理进行深入探讨,主要内容包括:明确控制文件的名称和存储路径,为数据库创建多路控制文件,将多路控制文件放在不同的硬盘上等。

通常我们采用多路控制文件或者备份控制文件的方法避免Oracle控制文件被破坏而导致的数据库无法启动的问题。因为Oracle控制文件具有保持Oracle数据库的完整性的功能,所以我们不得不重视。

Oracle控制文件是数据库建立的时候自动生成的二进制文件,只能通过实例进行修改,如果手动修改的话会造成控制文件与物理信息不符合,从而导致数据库不能正常工作。

控制文件主要包括下面内容:

1.控制文件所属数据库的名字,一个控制文件只能属一个数据库

2.数据库创建时间

3.数据文件的名称,位置,联机,脱机状态信息

4.所有表空间信息

5.当前日志序列号

6.最近检查点信息

其中,数据库名称,标识和创建时间在数据库创建时写入;数据文件和重做日志名称和位置在增加,重命名或者删除的时候更新;表空间信息在增加或者删除表空间的时候进行更新。

在初始化参数文件中control_files参数主要来描述控制文件的文件名跟物理路径,如下所示:

control_files=("d:oracleoradataoradbcontrol01.ctl")

该参数只设置一个,也可以设置多个,如下所示:

  1. control_files=("d:oracleoradataoradbcontrol01.ctl"  
  2. "e:oracleoradataoradbcontrol02.ctl",  
  3. "f:oracleoradataoradbcontrol03.ctl")  
  4.  

这个方法叫做多路控制文件,oracle可以利用这个方法恢复被破坏的控制文件,oracle最多允许设置8个多路控制文件。必须所有的多路控制文件都完整正确数据库才能正常启动,只要丢失一个或者一个内容不正确数据库就不能顺利启动。对控制文件的管理原则:

1.明确控制文件的名称和存储路径,参数设置错误将无法打开数据库,数据库打开以后,实例将同时写入所有的控制文件但是只会读取***个控制文件的内容。

2.为数据库创建多路控制文件
a.多路控制文件内容必须完全一样,oracle实例同时将内容写入到control_files变量所设置的控制文件中。
b.初始化参数control_files中列出的***个文件是数据库运行期间***可读取的控制文件。
c.创建,恢复和备份控制文件必须在数据库关闭的状态下运行,这样才能保证操作过程中控制文件不被修改。
d.数据库运行期间如果一个控制文件变为不可用,那么实例将不再运行,应该终止这个实例,并对破坏的控制文件进行修复。

3.将多路控制文件放在不同的硬盘上

4.采用操作系统镜像方式备份控制文件

5.手工方式备份控制文件

应该及时备份特别是发生了如下的操作的时候:
◆添加删除重命名数据文件
◆添加删除表空间,改变表空间读写状态
◆添加删除重做日志文件

如果手工备份不及时的话,就会产生备份的控制文件与正在使用的控制文件不一致,那么利用备份的控制文件启动数据库时会破坏数据库的一致性完整性,甚至不能启动数据库,因此手工备份控制文件要注意及时备份。

创建多路控制文件

利用spfile文件创建多路控制文件

(spfile以二进制文本形式存在,不能用vi编辑器对其中参数进行修改。文件格式为spfileSID.ora。如果要对spfile文件进行修改,可以采用SQL语言)

1.利用SYS帐号登陆SQL*PLUS,查询一下控制文件信息视图

  1. SQL>select name from v$controlfile;  

#p#

结果显示为:

  1. NAME  
  2. ----------------------------------  
  3. d:oracleoradataoradb01control01.ctl  
  4. e:oracleoradataoradb01control02.ctl  
  5. f:oracleoradataoradb01control03.ctl  
  6.  

这里列出了控制文件的名称以及位置

2.更改spfile中控制文件的信息:(增加了一个新的控制文件)

  1. SQL>alter system set control_files=  
  2. 'd:oracleoradataoradb01control01.ctl',  
  3. 'e:oracleoradataoradb01control02.ctl',  
  4. 'f:oracleoradataoradb01control03.ctl',  
  5. 'g:oracleoradataoradb01control04.ctl'  
  6. scope=spfile 
  7.  

结果显示为:

系统已经更改。

(第二步的操作需要注意的是:进行这些操作,必须是在DB启动的时候,否则会弹出“ORACLE not available”错误。)
 
3.关闭数据库

4.在操作系统中将已有的控制文件复制,修改名称保存到刚才增加控制文件的指定位置。(这步必须做的,否则数据库无法启动)

5.重新启动控制文件,使控制文件改变生效。

管理控制文件

备份控制文件

  1. SQL> alter database backup controlfile to ‘d:\20080326.ctl’ 

数据库已更改。

然后从这个备份的位置直接把文件拷贝回之前的目录覆盖就好了。

删除控制文件(删除某一路的控制文件)

spfile文件

1.利用SYS帐号登陆SQL*PLUS,查询一下控制文件信息视图

  1. SQL>select name from v$controlfile;  

结果显示为:

  1. NAME  
  2. ----------------------------------  
  3. d:oracleoradataoradb01control01.ctl  
  4. e:oracleoradataoradb01control02.ctl  
  5. f:oracleoradataoradb01control03.ctl  
  6. g:oracleoradataoradb01control04.ctl  
  7. 这里列出了控制文件的名称以及位置  
  8. 2.更改spfile中控制文件的信息,删除一个新的控制文件  
  9. SQL>alter system set control_files=  
  10. 'd:oracleoradataoradb01control01.ctl',  
  11. 'e:oracleoradataoradb01control02.ctl',  
  12. 'f:oracleoradataoradb01control03.ctl',  
  13. scope=spfile 
  14.  

结果显示为:

系统已经更改。

3.关闭数据库

4.在操作系统中删除控制文件

5.重新启动数据库,使控制文件生效

【编辑推荐】

  1. 修改Oracle存储过程所需代码
  2. 对Oracle存储过程的总结
  3. 实现Oracle存储过程的实际应用的代码 
  4. 深入高性能的Oracle动态SQL开发 
  5. Oracle SQL的优化规则解析 
责任编辑:佚名 来源: 地三鲜的个人空间
相关推荐

2012-07-31 09:55:50

时间管理管理

2010-04-14 17:11:13

Oracle管理

2010-10-26 10:24:06

Oracle控制文件

2016-12-12 16:17:22

华为

2011-04-12 13:08:42

Oracle虚拟专用数据

2010-11-19 13:01:31

Oracle日志文件

2015-07-23 09:19:31

虚拟化

2010-10-29 14:20:54

Oracle移动控制文

2010-11-19 11:51:40

Oracle密码文件

2010-04-09 17:35:22

2011-08-02 08:59:52

Oracle控制文件

2010-04-27 14:18:56

Oracle控制文件

2017-03-14 15:26:28

云日志安全管理

2009-06-29 18:09:12

多路复用Oracle

2014-04-14 15:27:01

2011-05-26 15:27:08

Oracle数据库

2019-12-24 09:39:06

Kubernetes工具微服务

2011-04-12 10:42:41

Oracle日志文件管理

2010-04-19 16:09:22

Oracle控制文件

2024-01-03 09:07:50

文件存储分块文件存储分片Net开发
点赞
收藏

51CTO技术栈公众号