配置归档日志,让数据库管理更加顺畅

  一、更改日志操作模式三步走。

  默认情况下,Oracle数据库采用的是非归档模式。但是,非归档模式不能够防止因物理损坏而导致丢失数据问题。为此数据库管理员可能需要把日志操作模式从非归档模式转换为归档模式。其实,要进行这个转换的话,只需要通过简单的三个步骤即可。不过在进行操作之前,要需要注意。以下的操作都必须要求用户具有数据库管理员的权限,即只有SYSDBA或者SYSOPER身份才能够执行如下的操作。

  要更改日志操作模式,具体操作步骤如下。

  第一步:先确定当前的日志操作模式。当数据库管理员更改当前操作日志模式之前,需要先确定一下当前日志操作模式。此时数据库管理员可以查询动态性能视图,来确认当前日志操作模式。如可以利用如下语句来查询我们所需要的信息。动态性能视图中存储着很多数据库运行信息。从中我们数据库管理员可以获取很多有用的信息。如现在要了解当前数据库的日志操作模式,就可以从数据库动态性能视图中获知。

  第二步:关闭数据库。如果确认数据库当前的日志操作模式为非归档模式,需要把它改为归档操作模式,需要先关闭当前运行的数据库,然后重新装载数据库。需要注意的是,更改日志操作模式只能够在MOUNT状态下进行,因此必须首先关闭数据库,然后重新装载数据库。另外,如果需要更改日志操作模式,那么在关闭数据库时不能够使用SHUTDOWN ABORT命令。SHUTDOWN ABORT命令的作用其实跟KILL进程具有同样的效果。若利用这个命令的话,可能会给数据库带来一些不利的因素。如可能导致文件状态不一致。在数据库正常关闭的时候,数据库会同步校验各个文件,使得重新启动的时候文件时间点一致并且不用进行崩溃修复。而使用这个命令不会进行这个检验。所以,采用SHUTDOWN ABORT命令关闭数据库的时候,可能会导致数据库启动出错,导致已经递交的数据丢失,甚至出现数据库崩溃的噩梦。所以,无论是在更换数据库日志操作模式,又或者其他原因需要关闭数据库的,最好不要采用这个命令。只有在采用其他关闭数据库命令不能够奏效的情况下,才能够使用这个命令。笔者建议通过SHUTDOWN IMMEDIATE命令来关闭数据库。

  数据库关闭之后,再利用Startup命令,把数据库启动到MOUNT状态。再次提醒一次,只有在Mount状态下才能够更改日志操作模式。

  第三步:更改日志操作模式。以上准备工作做好之后,就可以利用相关命令来更改日志操作模式。我们可以利用如下命令来进行更改。

  然后重新打开数据库之后,设置就生效了。

  二、手工对重做日志文件进行归档。

  有时候出于某些原因,数据库管理员可能需要手工对重做日志进行归档。在10G以后的版本中,默认情况下,当将日志操作模式从非归档模式转换为归档操作模式的时候,Oracle数据库会在后台自动启动一个ARCH进程。这个进程就是负责重做日志的备份任务。通常情况下,归档模式下,数据库会自动备份重做日志。

  若需要手工备份重做日志的话,即手工归档,则必须在改变操作日志模式中明确说明。即在上面的命令中,加入MANUAL参数。如果加入这个参数后,则数据库管理员就必须手工执行归档命令。如果数据库管理员没有手工执行归档命令的话,则日志组中的内容就无法被进行覆盖。所以通常情况下,除了一些特殊的需要,如数据库测试,才使用手工归档方式。否则的话,就还是采用自动归档方式更加的合理。值得一提的是,根据笔者了解,这个参数只是一个过渡参数。主要为了跟以前的Oracle数据库版本兼容。估计在不久之后,这个手工归档的参数会取消掉。

  三、设置归档文件的存储位置。

  在操作系统管理中,系统管理员往往会重新设置我的文档、IE收藏夹等存储位置。以防止系统奔溃时这些数据的丢失。其实,在Oracle归档日志文件管理中也是如此。当数据库管理员把日志操作模式从非归档模式转换为归档模式时,需要根据实际情况,重新设置归档文件的存储位置。

  当数据库处于归档模式时,如果进行日志切换,后台进程将自动生成归档日志文件。归档日志文件的默认存储位置为Oracle数据库安装目录下的RDBMS下。而在实际工作中,数据库管理员往往会改变其存储位置。如出于空间的考虑或者安全方面的考虑,会把归档日志存放在数据文件不同的硬盘中,等等。

  如果需要更改归档日志的操作文件,则需要变更相应的初始化参数。参数Log-Archive-Dest就是用来控制归档日志的存储路径的。通常情况下,若是没有备用数据库的话,则只需要把归档日志存放到服务器上的独立的硬盘中即可,而不需要进行异地备份。如果需要配置本地归档日志的存储路径,则可以通过以上的初始化参数以及Log-Archive-Duples_Dest参数。其中前面一个参数用来指定第一个归档日志的位置,第二个参数用来指定第二个归档日志的位置。当分别对以上两个参数进行配置后,数据库系统在进行日志切换时,后台进程就会生成两份完全相同的归档日志,分别存储在上面两个不同的路径中。这里需要强调的一点是,存放在两个不同路径中的归档日志文件是完全相同的。这主要是出于数据安全的需要。一般情况下,只需要一个归档日志即可。若不放心的话,则可以设置多个归档日志存放位置。不过这些归档日志最好能够存放到不同的磁盘上,否则的话,就没有多少的实际意义。

  除了以上这个配置参数之外,平时工作中,我们还经常会使用Log-Archive-Dest_N这个参数。这个参数主要用于指定多个归档位置,通常情况下,可以多大十个归档位置。这个参数跟先前提到的两个参数有比较大的不同。数据库管理员要对此有清晰的认识。只有如此,才能够根据自己的需要,选择合适的初始化参数。他们的差异主要有以下几点。

  一是不带N的初始化参数(即前面的两个参数)只能够用来配置本地归档位置。而后面谈到的这个参数这可以用来配置本地归档位置与远程归档位置。也就是说,如果数据库管理员要把归档日志文件保存在网络上的其它主机中时,就必须利用后面的参数进行配置。这个区别是几个参数之间最大的差异。不过由于网络传输等方面的限制,笔者并不建议把归档日志保存在其它主机上。而是建议在数据库服务器中增加一块独立的硬盘用来保存归档日志文件即可。因为硬盘之间数据的复制要比网络传输要快的多。这可以避免重做日志归档时对网络资源过多的占用,从而降低网络的性能。

  二是前面两个参数只能够配置两个不同的归档日志位置;而后面一个参数则可以配置多大十个归档日志文件位置。这是两者数量上的差异,不过没什么作用。对于大部分企业来说,可能两个归档日志文件存放位置已经可以满足他们的需求了。另外一个小的差异就是,后面这个参数不能够跟前面两个参数共存。为此,当使用后者这个参数时,就需要先把前面两个参数禁用掉。因为数据库默认情况下,是启动第一个初始化参数的。

  三是具体的配置也有所不同。利用后者参数指定归档日志存储位置时,如果配置本地归档位之,则需要指定Location选项;如果是配置远程归档日志位置时,则就需要制定Service选项,这个选项主要用来指定远程数据库的网络服务名。通常情况下,数据库管理员可以同时配置本地归档位置与远程归档位置。

  对于以上这些初始化参数,数据库管理员需要根据自己的工作习惯进行配置。一个基本的原则就是兼顾归档日志文件的安全性与其对性能的影响。其它没有硬性的规定。根据笔者的经验,如果这些初始化参数设置的好的话,可以让我们数据库管理的工作更加顺畅、便捷。

时间: 2024-09-28 12:02:22

配置归档日志,让数据库管理更加顺畅的相关文章

RMAN 配置归档日志删除策略

        Oracle 11g中对于归档日志的删除,除了遵循RMAN保留策略外,也可以通过RMAN来配置归档日志的删除策略,也就是归档日志何时可以被删除.归档日志删除策略适用于所有归档位置(使用快速闪回区FRA/不使用FRA).本文主要描述归档日志删除策略并给出了具体的演示.  1.关于归档日志删除策略      也就是哪些归档日志符合删除策略能够被删除,如前所述,归档位置适用于所有归档位置(使用快速闪回区FRA/不使用FRA)      当启用该策略后,如归档日志存在于FRA中,则Ora

查看oracle归档日志路径2

在Oracle中,数据一般是存放在数据文件中,不过数据库与Oracle最大的区别之一就是数据库可以在数据出错的时候进行恢复. 这个也就是我们常见的Oracle中的重做日志(REDO FILE)的功能了.在重做日志分成2部分,一个是在线重做日志文件,另外一个就是归档日志文件.      这里不详细说明在线重做日志,而是说一下归档日志(Archive Log).在线重做日志大小毕竟是有限的,当都写满了的时候,就面临着2个选择,第一个就是把以前在线重做日志从头擦除开始继续写,第二种就是把以前的在线重做

oracle物理结构(四)归档日志文件

归档日志文件是重做日志文件的截断备份,Oracle运行的两种模式:归档模式和不归档模式. 1.启用/禁用归档模式 SQL>archive log list; 查询归档模式 SQL>shutdown immediate SQL>startup mount SQL>alter database archivelog; SQL>alter database open; SQL>archive log list; Database log mode              A

delete archivelog all 无法彻底删除归档日志?

    最近在因归档日志暴增,使用delete archivelog all貌似无法清除所有的归档日志,到底是什么原因呢? 1.演示环境 SQL> select * from v$version where rownum<2; BANNER ---------------------------------------------------------------- Oracle Database 10g Release 10.2.0.3.0 - 64bit Production SQL&g

rman 还原归档日志(restore archivelog)

     听说过还原(restore)数据库,表空间及数据库文件,使用归档日志恢复(recover)数据库,表空间,数据库文件.咦,还有还原归档日志这一说法呢?没错,可能我们忽略了还原归档日志这一个过程,原因是还原归档日志通常情况下是oracle在recover时自动完成的.大多数情况下我们是先还原数据库,恢复数据库,打开数据库.实际上在恢复数据库之前有一个动作,那就是还原归档日志,也就是将日志文件还原到缺省的归档位置,如果我们在备份归档日志时使用了delete [all] input子句的话.

Oracle 归档日志

--==================== -- Oracle 归档日志 --====================       Oracle可以将联机日志文件保存到多个不同的位置,将联机日志转换为归档日志的过程称之为归档.相应的日志被称为归档日志.   一.归档日志     是联机重做日志组文件的一个副本     包含redo记录以及一个唯一的log sequence number     对日志组中的一个日志文件进行归档,如果该组其中一个损坏,则另一个可用的日志将会被归档     对于归

Oracle RMAN 清除归档日志

      在开发环境及UAT环境经常碰到需要清除归档日志的情形,对于这个问题方法有很多.可以直接使用rm方式清除归档日志,也可以使用find命令来查找符合条件的记录来清除归档日志,或者直接写个shell脚本来搞定.这样在DEV或者UAT还可以,但是在Prod环境还是建议使用RMAN提供的命令来搞定比较妥当.因为rm,find方式删除了实际的归档日志也释放了空间,但对应的存储在控制文件中的归档信息并没有彻底清除.依旧占用着一些空间未能及时清除而需要控制文件通过age out方式来释放空间.本文描

Oralce 归档日志开启与关闭示例_oracle

查看oracle数据库是否为归档模式 SQL> select name,log_mode from V$database; NAME LOG_MODE ------------------ ------------------------ TEST NOARCHIVELOG SQL> archive log list Database log mode No Archive Mode Automatic archival Disabled Archive destination USE_DB_

没有备份、只有归档日志,如何恢复数据文件?

备份|恢复|数据 没有备份.只有归档日志,如何恢复数据文件?系统环境: 1.操作系统:Windows 2000 Server,机器内存128M2.数据库: Oracle 8i R2 (8.1.6) for NT 企业版3.安装路径:C:\ORACLE模拟现象: 可通过重建数据文件来恢复,前提是归档日志文件保存完整先将数据库设置为归档模式SQL*Plusconn system/manager--创建实验表空间create tablespace test datafile'c:\test.ora'