Oracle会产生许多文件和文件组,这些文件存储着重要的信息。本节就介绍这些文件和文件组。

一、Oracle控制文件

Oracle控制文件是Oracle数据库存储信息的重要文件,它是一个二进制文件,控制文件主要用来存放数据库名字、数据文件位置等信息的文件。Oracle控制文件是至关重要的,没有了它,数据库就不能启动。

每一个数据库都有一个Oracle控制文件,而且每一个控制文件只属于一个数据库,不能拿来共用。控制文件在数据库创建时跟着一起创建,控制文件不能手动修改,Oracle数据库自己独立管理。

那控制文件的状态和存放位置是如何的呢?我们可以根据数据字典V$controlfile进行查询,查询结果如下:

通过查询结果,可以看出控制文件的扩展名是.ctl文件。每一个控制文件都记录着Oracle数据库的创建时间、名称、数据文件的名字、数据文件的位置、日志文件的名字及位置、表空间、备份、最近检查点等信息。因此在对数据库进行相应的操作时,比如增加数据文件时,就会更新对应的控制文件信息,而不是手动进行修改。

控制文件多路复用

既然控制文件这么重要,我们该如何对它进行保护呢?Oracle数据库提供了多路复用机制对控制文件进行保护。多路复用就是把控制文件进行复制创建在不同磁盘上,这样子可以防止一个磁盘在损坏的情况下,可以从其它磁盘上进行恢复。保证Oracle数据库的安全性。

可以使用init.ora文件对控制文件进行多路复用,init.ora是Oracle数据库初始化文件,它也是Oracle创建时,就自动创建的一个文件,它里面包含了控制文件的位置信息,init.ora文件在Oracle数据库安装目录下dbs文件下。

在修改init.ora之前可以对Oracle控制文件进行备份,然后再修改init.ora文件中control_files参数。步骤如下:

1、查看参数文件spfile位置,把参数文件转换为可以编辑文件pfile--查看参数文件spfile位置

show parameter spfile;

--创建pfile

create pfile from spfile;

2、关闭数据库。

3、对控制文件进行备份,然后对pfile文件进行修改,把contol_files参数添加上备份的控制文件。

4、再创建spfile文件,然后重启数据库。create spfile from pfile;

通过查询控制文件V$controlfile可以查询正好有两个控制文件,和init.ora文件中两个控制文件一一对应。因此可以通过备份控制文件,然后通过init.ora文件对控制文件进行多路复用,从而起到保护Oracle数据库的作用。

二、日志文件

Oracle日志文件是Oracle数据库存储信息的重要文件,主要用来存储数据库变化的操作信息。

Oracle日志文件可以分为两种:重做日志文件(redo log file)、归档日志文件,其中重做日志文件主要记录了数据库的操作过程,可以在进行数据库恢复时,将重做日志文件在还原的数据库上进行执行,以达到数据库的最新状态。

Oracle数据库在运行时,可以选择是否开启归档日志,在非归档日志的情况下,Oracle所有的操作日志都写在重做日志当中,当所有重做日志文件写满时(Oracle重做日志是分组的,默认是分为三组),那么就把前面的日志文件覆盖继续写入。而在开启归档日志模式情况下,当重做日志都写满时,继续要写入日志时,会把要覆盖的日志文件写入归档日志当中,然后再对重做日志进行覆盖,因此使用归档日志利于后期进行数据恢复。

那要怎么查看数据库是否开启归档日志?可以根据以下命令进行查询:select t.NAME,t.LOG_MODE from v$database t;

代码解析:V$database数据字典主要存储数据库创建后的一些配置信息,其中LOG_MODE字段记录的就是是否开启归档日志文件,NOARCHIVELOG:表示未开启归档日志文件(Oracle在安装时默认选择的是不开启归档日志模式的)。

那重做日志文件的位置和属性信息如何查询,我们可以根据数据字典V$logfile进行查询,代码如下:select *from v$logfile;

三、管理日志文件

通过上一小节Oracle日志文件的了解,我们已经知道日志文件的作用和重要性,本章节介绍Oracle如何对日志文件进行管理的。

Oracle数据库利用日志文件组对日志文件进行分组管理,Oracle数据库默认安装的是三个重做日志,三个日志文件组,每组一个日志文件,如下图:

其中status中current表示的是当前日志文件是正在使用(写入)的。

在实际使用当中,随着业务量的增大,操作数据库会变得频繁,日志文件读写切换太快,导致出现检查点等待问题,所以一般要增加或增大重做日志文件,或者直接一起增加日志文件组来解决性能问题。

因此,Oracle经常用到添加日志文件组、添加日志文件进文件组、删除日志文件、删除日志文件组四种方式对日志文件进行管理。具体命令步骤参考如下:

1、Oracle添加日志文件组

2、Oracle添加日志文件进文件组

3、Oracle删除日志文件

4、Oracle删除日志文件组

1、Oracle添加日志文件组

我们知道Oracle通过添加日志文件组达到扩充日志文件组的目的,然后再进行对其添加特定的日志文件,就达到扩充日志文件数的目的,解决了日志文件过少的性能问题。

Oracle增加日志文件组可以使用OEM企业管理器、SQL命令两种方式进行添加。这里我们采用SQL命令方式进行讲解,OEM企业管理器方式读者门可以自行试验。

创建日志文件组语法结构:alter database

add logfile group n

filename size m

语法解析:

1、group n:表示创建日志文件组的组号,在Oracle当中日志文件组的组号是唯一的。

2、filename:表示日志文件组存储的位置。

3、size m:表示日志文件组的大小,默认是50M大小。

下面我们增加一个新的日志文件组4,大小100M,代码如下:alter database

add logfile group 4

'E:\APP\ADMIN\ORADATA\ORCL\NEWREDO04.LOG' size 100M;

执行完代码再看下日志文件组数量,如图:

2、Oracle添加日志文件进文件组

我们知道Oracle可以通过添加日志文件进特定的文件组以达到扩充日志文件数的目的,解决了日志文件过少的性能问题。

Oracle数据库中一个日志文件组可以包含多个日志文件,但是必须包含一个文件。因此,我们可以对建好的日志文件组进行扩充,语法结构如下:alter database

add logfile member

filename to group n;

语法解析:

1、filename:表示日志文件存储的位置。

2、group n:表示添加到那个日志文件组。

利用上面的命令,我们对日志文件组4再添加一个日志文件,命令如下:alter database

add logfile member

'E:\APP\ADMIN\ORADATA\ORCL\NEWREDO05.LOG' to group 4;

执行完代码,再查下一下日志文件,发现多了一个新添加的日志文件。

3、Oracle删除日志文件

我们知道Oracle日志文件的重要性,我们不仅仅可以对日志文件组中进行添加日志文件,也可以把不必要的日志文件进行删除。

Oracle删除日志文件的语法结构如下:alter database

drop logfile member

filename

语法解析:

1、filename:日志文件存储的位置。

2、当日志文件组只有一个日志文件时,是不能进行删除日志文件的,必须把整个日志文件组进行删除。

利用删除日志文件的命令,把刚刚添加的日志文件NEWREDO05进行删除,代码命令如下:alter database

drop logfile member

'E:\APP\ADMIN\ORADATA\ORCL\NEWREDO05.LOG'

执行完代码,在查下日志文件,发现日志文件NEWREDO05已经删除了,如下图:

4、删除日志文件组

我们知道Oracle日志文件的重要性,我们不仅仅可以增加日志文件组,也可以对于过多的日志文件组进行整组删除。

Oracle删除日志文件组的语法结构:alter database

drop logfile

group n

语法解析:

1、group n:表示要删除的文件组组号。

2、删除文件组,会对应的里面的日志文件一并全部删除。

利用删除日志文件组命令,把文件组4整组删除,代码如下:alter database

drop logfile

group 4;

执行完代码,再查看下日志文件,发现日志文件组4,已经全部删除。如下图:

转载本站内容时,请务必注明来自W3xue,违者必究。

oracle增加文件组,Oracle 文件和文件组相关推荐

  1. oracle 增加间隔分区,oracle分区表之间隔分区(oracle 11g) - 漫兮网

    范围分区允许用户根据分区键列值的范围创建分区.下面是一个按范围分区表的示例: create table sales6 ( sales_id number, sales_dt date ) partit ...

  2. oracle增加网络服务,Oracle 配置监听和本地网络服务

    一.配置监听 在oracle的配置和移植工具中打开Net Configuration Assistant,然后点击下一步. 点击下一步,然后输入监听的名称点击下一步 点击下一步后如图 点击下一步如图 ...

  3. oracle增加字段失败,oracle添加字段引起的问题

    author:skate time:2010-05-27 oracle添加字段引起的问题 由于同事在添加了表的字段后,没有重新编译数据库的对象,导致和这个表相关的很多procedure和package ...

  4. oracle 增加列 生效,oracle基础(表的创建,插入,修改,增加,列的问题)

    创建表 create table tb_user( user_name varchar2(40) not null, user_sex varchar2(10) not null, user_age ...

  5. oracle rac alter日志,ORACLE 11G RAC 增加日志组及增大日志文件

    1.查看目前日志组和日志文件情况 SQL> select * from v$logfile order by 1; GROUP# STATUS  TYPE    MEMBER           ...

  6. 向oracle增加两个重做日志组文件,Oracle重做日志文件

    Oracle重做日志文件 原理:重做日志记录将以循环的方式在sga区的重做日志高速缓冲区中进行缓存,并由后台进程LGWR写入到重做日志文件中. 重做日志文件记录了对数据文件的修改操作,还记录了对回滚段 ...

  7. oracle 增加ora容量_oracle数据库报错:ORA-01653无法在表空间扩展解决办法 ,增加表空间或表空间增加数据文件...

    当Oracle数据库的数据量越来越大,表空间的大小不够用的时候,会报错:"ORA-01653 ", 即表空间满了,无法在表空间扩展解决办法 ,增加表空间或表空间增加数据文件.在这里 ...

  8. oracle 新增加控制文件,Oracle增加控制文件副本

    1.文档目标 新建的数据库只有一个控制文件副本,希望增加控制文件副本到不同位置,防止控制文件发生损坏. 2.修改control_files参数 # 如果使用了OMF则可以在修改参数时只指定路径,无需指 ...

  9. 查询oracle的联机日志文件,查询Oracle日志文件的方法(摘自http://database.51cto.com/art/201010/231519.htm)...

    Oracle日志文件相信经常使用Oracle数据库的朋友都比较熟悉了,下面将为您介绍的是查询Oracle日志文件的几种方法,供您参考学习. 1.查询系统使用的是哪一组日志文件: select * fr ...

最新文章

  1. [系统安全] 六.逆向分析之条件语句和循环语句源码还原及流程控制
  2. honeywell新风系统控制面板说明_新风系统——不开窗也能清新呼吸
  3. 在iOS平台使用libcurl
  4. Centos之常用命令
  5. IIS 7.0与ASP.NET
  6. 媒体查询@media scree
  7. php pdo exec,PDO::exec
  8. visio2013剪除_Visio 2003 图形剪切合并 高级技巧
  9. 【Camera】Camera中光圈系数概念以及光圈的作用
  10. 鹏鹏:You have 14 unapplied migration(s). Your project may not work properly。。。。报错!
  11. 北京近期校园招聘java_JAVA研发工程师-校招,北京
  12. Uber Go 语言编程规范:使用 go.uber.org/atomic
  13. 计算机软件定时运行,做一回达人 Windows7定时运行程序
  14. 安装linux系统时将选择下列哪一个操作,linux操作系统考试试卷
  15. 大专计算机应用论文摘要,计算机应用大专论文摘要怎么写 计算机应用大专论文摘要范文参考...
  16. 专业实训---摩拜共享单车
  17. Java字节码文件和二进制文件的区别与联系
  18. ExcelVba_调用jQuery计算Md5和CRC32
  19. 卡巴斯基发布操作系统Kaspersky OS
  20. 手机视频监控软件功能需求

热门文章

  1. 求图形学基本算法好书推荐?
  2. 阿里云ACE认证之理解CDN技术
  3. Bzoj5251: [2018多省省队联测]劈配
  4. centos上实现动态路由和NAT功能
  5. 山寨一个ini文件的解析器
  6. 【MySQL数据库开发之四】MySQL 处理模式/常用查询/模式匹配等(下)
  7. python列表套着列表_python 列表套列表去重
  8. matlab uigetfile的用法,matlab中uigetfile的用法
  9. python里的π怎么调用_用python计算圆周率π
  10. 电脑位数怎么看_看完了这篇文章你就知道怎么选电脑了...