ORACLE归档模式与非归档模式

来源:互联网 发布:数据来源于天地图 编辑:程序博客网 时间:2024/05/01 19:02

一、 什么是ORACLE归档模式

        ORACLE数据库有联机重做日志, 这个日志是记录对数据库所做的修改, 比如插入、删除、更新数据等, 对这些操作都会记录在联机重做日志里。一般数据库至少要有2个联机重做日志组。当一个联机重做日志组被写满的时候,  就会发生日志切换, 这时联机重做日志组2成为当前使用的日志, 当联机重做日志组2写满时候, 又会发生日志切换, 去写联机重做日志组1, 就这样反复进行。

        如果数据库处于非归档模式, 联机日志在切换时就会丢弃, 而在归档模式下, 当发生日志切换的时候, 被切换的日志会进行归档。比如, 当前在使用联机重做日志1, 当1写满的时候, 发生日志切换, 开始写联机重做日志2, 这时联机重做日志1的内容会被拷贝到另外一个指定的目录下。这个目录叫做归档目录, 拷贝的文件叫归档重做日志

        数据库使用归档方式运行时候才可以进行灾难性恢复

二、 归档模式与非归档模式的在备份上的区别

          非归档模式只能做冷备份, 并且恢复时只能做完全备份, 最近一次完全备份到系统出错期间的数据不能恢复。

          归档模式可以做热备份, 并且可以做增量备份, 可以做部分恢复

三、 查看ORACLE数据库是否为归档模式

          3.1 SQL代码

           SELECT NAME, LOG_MODE FROM V$DATABASE ;
                 NAME                          LOG_MODE

                 COGNOS                    NOARCHIVELOG

          3.2 使用ARCHIVE LOG LIST命令

                 DATABASE LOG MODE       NO ARCHIVE MODE

                 AUTOMATIC ARCHIVAL       DISABLED

                 ARCHIVE DESTINATION     USE_DB_RECOVERY_FILE_DEST

                 OLDEST ONLINE LOG SEQUENCE (最早的联机日志序列)     81

                 CURRENT LOG SEQUENCE(当前的联机日志序列)                  83

四、 配置数据库的归档模式

           4.1 改变非归档模式到归档模式

                 SHUTDOWN IMMEDIATE ;  先关闭数据库

                 STARTUP   MOUNT ; 启动数据库到装载状态, 但不要打开

                 ALTER DATABASE ARCHIVELOG ; 设置数据库为归档日志模式

                 ALTER DATABASE OPEN ; 打开数据库

                 ARCHIVE LOG LIST ;  确认数据库现在处于归档模式

                 ARCHIVE LOG ALL ; 将这个时间点的redo logs归档

                

                 做一次完全备份, 因为非归档日志模式下产生的备份日志对于归档模式已经不可用了, 这一步非常重要!!!

                 ALTR TABLESPACE USERS BEGIN BACKUP ;

    

            4.2 改变归档模式到非归档模式

                   SHUTDOWN IMMEDIATE ;  先关闭数据库

                   STARTUP   MOUNT ; 启动数据库到装载状态, 但不要打开

                   ALTER DATABASE NOARCHIVELOG ; 设置数据库为非归档模式

                   ALTER DATABASE OPEN ; 打开数据库

五、启动自动归档

        先关闭数据库, 在PFILE中添加LOG_ARCHIVE_START=TRUE ; 重新启动数据库。

        或者

        ALTER SYSTEM ARCHIVE LOG START ;

        归档模式下, 日志文件组不允许被覆盖(重写), 当日志文件写满以后, 如果没有进行手动归档, 那么系统将挂起,直到归档完成为止。这时只能读而不能写。

        运行过程中关闭和重启归档日志进程

        ARCHIVE LOG STOP ;

       ARCHIVE LOG START ;

六、手动归档

        LOG_ARCHIVE_START=FALSE ;

        归档当前日志文件

        ALTER SYSTEM ARCHIVE LOG CURRENT ;

        归档序号为052的日志文件

        ALTER SYSTEM ARCHIVE LOG SEQUENCE 052 ;

        归档所有日志文件

        ALTER SYSTEM ARCHIVE LOG ALL ;

        改变归档日志目标

        ALTER SYSTEM ARCHIVE LOG CURRENT TO '$PATH' ;

七、配置多个归档进程

        什么时候需要使用多个归档进程?

        如果归档过程会消耗大量的时间, 那么可以启动多个归档进程, 这个动态参数, 可以用ALTER SYSTEM动态修改。

        ALTER SYSTEM SET LOG_ARCHIVE_MAX_PROCESSES=10 ;

        ORACLE9i中最多可以指定10个归档进程, 与归档进程有关的动态性能视图: v$bgprocess, v$archive_processed

八、配置归档目标, 多归档目标, 远程归档目标, 归档日志格式

        归档目标:

        LOG_ARCHIVE_DEST_n

        本地归档目标:

        LOG_ARCHIVE_DEST_1 = "LOCATION=D:ORACLEARCHIVELOG" ;

        远程归档目标:

        LOG_ARCHIVE_DEST_2="SERVICE=STANDBY_DB1" ;

        强制归档目标, 如果出错, 600秒后重试:

        ALTER SYSTEM SET LOG_ARCHIVE_DEST_4="LOCATION=E:ORACLEARCHIVELOG MANDATORY REOPEN=600" ;

        可选的归档目标, 如果出错, 放弃归档:

        ALTER SYSTEM SET LOG_ARCHIVE_DEST_3="LOCATION=E:ORACLEARCHIVELOG OPTIONAL" ;

        归档目标状态:

         关闭归档目标:

         ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_1 = DEFER ;

         打开归档目标:

         ALTER SYSTEM SET LOG_ARCHIVE_DEST_STATE_2 = ENABLE ;

九、归档日志格式化

        LOG_ARCHIVE_FORMAT 默认的是%t_%s_%r.dbf

        其中%t代表thread number

                %s代表log sequence number

                %r代表重做日志id

十、与归档日志有关的几个视图:

        V$ARCHIVED_LOG

        V$ARCHIVE_DEST

        V$LOG_HISTORY

        V$DATABASE

        V$ARCHIVE_PROCESSES

     

       

        

 

                 

 

    

 

0 0
原创粉丝点击