热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

Oracle归档日志

----Oracle归档日志--Oracle可以将联机日志文件保存到多个不同的位置,将联机日志转换为归档日志的过程称之为归档。相应的日志被称为归档日志。一、归档日志是联机重做日志组文件的一个副本包含redo记录

--==================== -- Oracle 归档日志 --==================== Oracle 可以将联机日志文件保存到多个不同的位置,将联机日志转换为归档日志的过程称之为归档。相应的日志被称为归档日志。 一、归档日志 是联机重做日志组文件的一个副本 包含 redo 记录



--====================

-- Oracle 归档日志

--====================

Oracle可以将联机日志文件保存到多个不同的位置,将联机日志转换为归档日志的过程称之为归档。相应的日志被称为归档日志。

一、归档日志

是联机重做日志组文件的一个副本

包含redo记录以及一个唯一的log sequence number

对日志组中的一个日志文件进行归档,如果该组其中一个损坏,则另一个可用的日志将会被归档

对于归档模式的日志切换,当日志归档完成后,下一个日志才能被覆盖或重新使用

自动归档功能如开启,则后台进程arcn在日志切换时自动完成归档,否则需要手动归档

归档日志用途

恢复数据库

更新standby数据库

使用LogMiner 提取历史日志的相关信息

二、日志的两种模式

1.非归档模式

不适用与生产数据库

创建数据库时,缺省的日志管理模式为非归档模式

当日志切换,检查点产生后,联机重做日志文件即可被重新使用

联机日志被覆盖后,介质恢复仅仅支持到最近的完整备份

不支持联机备份表空间,一个表空间损坏将导致整个数据库不可用,需要删除掉损坏的表空间或从备份恢复

对于操作系统级别的数据库备份需要将数据库一致性关闭

应当备份所有的数据文件、控制文件(单个)、参数文件、密码文件、联机日志文件(可选)

2.归档模式

能够对联机日志文件进行归档,生产数据库强烈建议归档

在日志切换时,下一个即将被写入日志组必须归档完成之后,日志组才可以使用

归档日志的Log sequence number信息会记录到控制文件之中

必须有足够的磁盘空间用于存放归档日志

Oracle 9i 需要设置参数log_archive_start=true 才能够进行自动归档

备份与恢复

支持热备份,且当某个非系统表空间损坏,数据库仍然处于可用状态,且支持在线恢复

使用归档日志能够实现联机或脱机时点恢复(即可以恢复到指定的时间点、指定的归档日志或指定的SCN)

三、两种模式的切换设置及手动归档

1.非归档到归档模式

a.一致性关闭数据库(shutdown [immediate | transactional |normal])

b.启动到mount阶段(startup mount)

c.切换到归档模式(alter database archivelog [manual])

d.切换到open阶段(alter database open)

e.对数据做一个完整备份(full backup)

--演示非归档到归档模式

SQL> ARCHIVE LOG LIST --查看数据库是否处于归档模式

Database log mode No Archive Mode

Automatic archival Disabled

Archive destination USE_DB_RECOVERY_FILE_DEST

Oldest online log sequence 14

Current log sequence 16

SQL> SELECT log_mode FROM v$database; --查看数据库是否处于归档模式

LOG_MODE

------------

NOARCHIVELOG

SQL> SHUTDOWN IMMEDIATE; --一致性关闭数据库

Database closed.

Database dismounted.

ORACLE instance shut down.

SQL> STARTUP MOUNT; --启动到mount状态

ORACLE instance started.

Total System Global Area 251658240 bytes

Fixed Size 1218796 bytes

Variable Size 75499284 bytes

Database Buffers 171966464 bytes

Redo Buffers 2973696 bytes

Database mounted.

SQL> ALTER DATABASE ARCHIVELOG; --切换到自动归档模式

Database altered.

SQL> ALTER DATABASE OPEN; --切换到open状态

Database altered.

SQL> ARCHIVE LOG LIST; --查看数据库的归档状态

Database log mode Archive Mode --已置为归档模式

Automatic archival Enabled --对日志进行自动归档

Archive destination USE_DB_RECOVERY_FILE_DEST

Oldest online log sequence 14

Next log sequence to archive 16

Current log sequence 16

--备份数据库步骤省略

2.归档模式切换到非归档模式(步骤同非归档到归档模式仅仅是c步骤使用alter database noarchivelog,演示省略)

a.一致性关闭数据库(shutdown [immediate | transactional |normal])

b.启动到mount阶段(startup mount)

c.切换到归档模式(alter database noarchivelog )

d.切换到open阶段(alter database open)

e.对数据做一个完整备份(full backup)

3.手动归档

手动归档时需要将日志模式切换为alter database archivelog manual

再使用alter system archive log current | all 实现归档

更多手动归档命令:ALTER SYSTEM archive_log_clause

注意:

手动归档模式下不支持stanby数据库

alter database archivelog模式下也可以实现对日志的归档

SQL> ALTER DATABASE ARCHIVELOG MANUAL; --将日志模式切换为手工归档模式

Database altered.

SQL> ALTER DATABASE OPEN; --打开数据库

Database altered.

SQL> ALTER SYSTEM ARCHIVE LOG CURRENT; --对当前的日志进行归档(建议在mount阶段完成)

System altered.

SQL> ALTER SYSTEM ARCHIVE LOG ALL; --对所有的日志进行归档

alter system archive log all

*

ERROR at line 1:

ORA-00271: there are no logs that need archiving --没有需要归档的日志

4.归档进程的调整

通过设置LOG_ARCHIVE_MAX_PROCESSES 参数,可以指定数据库规定所需初始化的进程数,缺省的归档进程数为2

一般情况下不需要修改该参数,Oracle会根据归档情况自动启动额外的归档进程

也可以动态的增加或减少归档进程数,比如有些业务在月底需要进行大量归档,平时则归档较少,对此可以动态修改

修改方法

ALTER SYSTEM SET LOG_ARCHIVE_MAX_PROCESSES=3;

5.配置归档(两种归档位置配置方法)

a.归档到本机且少于等于两个归档位置

设置LOG_ARCHIVE_DESTLOG_ARCHIVE_DUPLEX_DEST参数

alter system set log_archive_dest = '/u01/app/oracle/archivelog1' scope = spfile;

alter system set log_archive_duplex_dest = '/u01/app/oracle/archivelog2' scope = spfile;

b.归档到本机或远程主机

设置LOG_ARCHIVE_DEST_n 参数,n最大值为10

alter system set log_archive_dest_1 = 'LOCATION=/u01/app/oracle/archivelog3';

alter system set log_archive_dest_2 = 'SERVICE=standby1';

对于远程归档位置,SERVICE选项需要指定远程数据库的网络服务名(tnsnames.ora文件中配置)

LOG_ARCHIVE_DEST_n的两个常用选项

MANADATORY | OPTIONAL:

MANADATORY表示归档必须成功复制到目的路径之后,联机重做日志才能被复用,OPTIONAL正好相反

REOPEN

指定归档失败后指定间隔多少时间重试归案,缺省的为300

示例:

log_archive_dest_1 = 'LOCATION=/u01/app/oracle/archivelog3 manadatory reopen = 600'

log_archive_dest_2 = 'SERVICE=standby1 manadatory reopen'

c.两种归档方法异同(前者log_archive_destlog_archive_duplex_dest ,后者log_archive_dest_n)

两者都可以归档到本机,后者可以归档到远程主机,前者不支持该功能

前者最多配置两个归档位置,后者可以配置10个归档位置

两者互不兼容,要么使用前者,要么使用后者

使用后者归档到本地时需要增加LOCATION选项,备份到远程主机需要使用SERVICE选项

但上述两种方式未指定路径时,归档日志位于db_recovery_file_dest 缺省为$ORACLE_BASE/flash_recovey_area

d.归档日志命名格式

设置LOG_ARCHIVE_FORMAT参数,Unix下的缺省设置为LOG_ARCHIVE_FORMAT=%t_%s_%r.dbf

%s: 日志序列号:

%S: 日志序列号(带有前导)

%t: 重做线程编号.

%T: 重做线程编号(带有前导)

%a: 活动ID

%d: 数据库ID

%r RESETLOGSID值.

alter system set log_archive_format = 'arch_%t_%s_%r.arc';

e.归档位置状态

Valid/Invalid --磁盘位置及服务名等是否有效

Enabled/Disabled --磁盘位置的可用状态及数据库能否使用该归档位置

Active/Inactive --访问归档目的地是否有异常

f.归档成功的最小个数(使用参数log_archive_min_succeed_dest = n)

alter system set log_archive_min_succeed_dest = 2; --缺省为1

联机重做日志组能够被覆盖的前提

所有强制路径归档位置成功实现归档

归档目的地的成功归档的个数大于或等于上述参数设定的值

当强制个数大于该参数设定的个数,则以强制个数为准

当强制个数小于该参数设定的个数,则可选的成功归档路径加上强制的归档路径个数至少等于该参数设定值

g.控制归档的可用性(使用参数log_archive_dest_state_n)

alter system set log_archive_dest_state_1 = enable | defer

enable -->缺省状态,可以在该归档位置进行归档

defer -->禁用该归档位置

h.演示归档路径配置及查看归档进程,归档位置状态

SQL> ARCHIVE LOG LIST; --查看日志是否处于归档状态

Database log mode Archive Mode

Automatic archival Enabled

Archive destination USE_DB_RECOVERY_FILE_DEST

Oldest online log sequence 24

Next log sequence to archive 26

Current log sequence 26

SQL> ho ps -ef | grep ora_arc --查看归档进程是否已启动

oracle 4062 1 0 11:43 ? 00:00:00 ora_arc0_orcl

oracle 4064 1 0 11:43 ? 00:00:00 ora_arc1_orcl

SQL> SHOW PARAMETER ARCHIVE --查看归档路径是否已设置,为空值表示未设置

NAME TYPE VALUE

------------------------------------ ----------- ------------------------------

archive_lag_target integer 0

log_archive_config string

log_archive_dest string

log_archive_dest_1 string

log_archive_dest_10 string

log_archive_dest_2 string

log_archive_dest_3 string

log_archive_dest_4 string

log_archive_dest_5 string

log_archive_dest_6 string

log_archive_dest_7 string

NAME TYPE VALUE

------------------------------------ ----------- ------------------------------

log_archive_dest_8 string

log_archive_dest_9 string

log_archive_dest_state_1 string enable

log_archive_dest_state_10 string enable

log_archive_dest_state_2 string enable

log_archive_dest_state_3 string enable

log_archive_dest_state_4 string enable

log_archive_dest_state_5 string enable

log_archive_dest_state_6 string enable

log_archive_dest_state_7 string enable

log_archive_dest_state_8 string enable

NAME TYPE VALUE

------------------------------------ ----------- ------------------------------

log_archive_dest_state_9 string enable

log_archive_duplex_dest string

log_archive_format string %t_%s_%r.dbf

log_archive_local_first boolean TRUE

log_archive_max_processes integer 2

log_archive_min_succeed_dest integer 1

log_archive_start boolean FALSE --该参数在9i中使用

log_archive_trace integer 0

remote_archive_enable string true

standby_archive_dest string ?/dbs/arch

SQL> alter system set log_archive_dest = '/u01/app/oracle/archivelog1' scope = spfile;

System altered.

SQL> alter system set log_archive_duplex_dest= '/u01/app/oracle/archivelog2' scope=spfile;

System altered.

SQL> alter system set log_archive_format = 'arch_%t_%s_%r.arc' scope = spfile;

--设定完毕后需要重新启动实例,在此省略关闭启动信息

SQL> ho ls /u01/app/oracle/archivelog1 --查看归档路径下是否存在文件或文件夹

SQL> ho ls /u01/app/oracle/archivelog2 --查看归档路径下是否存在文件或文件夹

SQL> alter system archive log current; --手动进行归档

System altered.

SQL> ho ls -l /u01/app/oracle/archivelog1 --在指定的文件夹archivelog1已产生归档日志

total 18224

-rw------- 1 oracle oinstall 18636800 Jul 28 20:39 arch_1_26_724852763.arc

SQL> ho ls -l /u01/app/oracle/archivelog2 --在指定的文件夹archivelog2已产生归档日志

total 18224

-rw------- 1 oracle oinstall 18636800 Jul 28 20:39 arch_1_26_724852763.arc

SQL> ho mkdir /u01/app/oracle/archivelog3 --创建新的归档路径

SQL> ho mkdir /u01/app/oracle/archivelog4 --创建新的归档路径

SQL> alter system set log_archive_dest_1 = 'location=/u01/app/oracle/archivelog3'

2 scope = spfile;

System altered.

SQL> alter system set log_archive_dest_2 = 'location=/u01/app/oracle/archivelog4'

2 scope = spfile;

System altered.

SQL> shutdown immediate; --关闭实例

Database closed.

Database dismounted.

ORACLE instance shut down.

SQL> startup --启动实例后,收到错误提示表明两种归档方式不兼容

ORA-16019: cannot use LOG_ARCHIVE_DEST_1 with LOG_ARCHIVE_DEST or LOG_ARCHIVE_DUPLEX_DEST

--关于上述设置导致的错误处理请参照:又一例SPFILE设置错误导致数据库无法启动

SPFILE错误导致数据库无法启动

--下面是正确的处理办法,应当先将一种归档方式路径置空,此处是将log_archive_dest置空

SQL> alter system set log_archive_dest = '' scope = spfile;

System altered.

--此处是将log_archive_duplex_dest置空

SQL> alter system set log_archive_duplex_dest = '' scope = spfile;

System altered.

--接下来再设定log_archive_dest_1log_archive_dest_2

SQL> alter system set log_archive_dest_1 = 'location=/u01/app/oracle/archivelog3'

2 scope = spfile;

System altered.

SQL> alter system set log_archive_dest_2 = 'location=/u01/app/oracle/archivelog4'

2 scope = spfile;

System altered.

--由于没有配置standby服务器,所以省略配置到远程主机

--设定完毕后需要重新启动实例,此时系统能正常启动,在此省略关闭启动信息

SQL> alter system archive log current; --进行手动归档

System altered.

SQL> ho ls -l /u01/app/oracle/archivelog3/ --查看归档日志

total 27752

-rw------- 1 oracle oinstall 28382208 Aug 2 13:46 arc_1_38_724852763.arc

SQL> ho ls -l /u01/app/oracle/archivelog4/ --查看归档日志

total 27752

-rw------- 1 oracle oinstall 28382208 Aug 2 13:45 arc_1_38_724852763.arc

SQL> col dest_name format a20;

SQL> col destination format a30;

SQL> select dest_name,status,archiver,destination,

2 log_sequence,reopen_secs,transmit_mode,process

3 from v$archive_dest; --查看归档目的地的相关状态信息

DEST_NAME STATUS ARCHIVER DESTINATION LOG_SEQUENCE REOPEN_SECS TRANSMIT_MOD PROCESS

-------------------- --------- ---------- ------------------------------ ------------ ----------- ------------ -------

LOG_ARCHIVE_DEST_1 VALID ARCH /u01/app/oracle/archivelog3/ 38 300 SYNCHRONOUS ARCH

LOG_ARCHIVE_DEST_2 VALID ARCH /u01/app/oracle/archivelog4/ 38 300 SYNCHRONOUS ARCH

LOG_ARCHIVE_DEST_3 INACTIVE ARCH 0 0 SYNCHRONOUS ARCH

-----------------------------------------------------------------------------------------------------------------------

SQL> alter system set log_archive_dest_state_2 = defer; --停用log_archive_dest_state_2

System altered.

SQL> show parameter log_archive_dest_state

NAME TYPE VALUE

------------------------------------ ----------- ---------------

log_archive_dest_state_1 string enable

log_archive_dest_state_10 string enable

log_archive_dest_state_2 string DEFER --该路径显示为defer

log_archive_dest_state_3 string enable

log_archive_dest_state_4 string enable

log_archive_dest_state_5 string enable

log_archive_dest_state_6

推荐阅读
  • 本文探讨了Web开发与游戏开发之间的主要区别,旨在帮助开发者更好地理解两种开发领域的特性和需求。文章基于作者的实际经验和网络资料整理而成。 ... [详细]
  • 本文详细探讨了在服务器上运行的PostgreSQL数据库出现'内存不足'错误的具体情况,并提供了一系列有效的解决策略。通过本文,读者将能够更好地理解这一常见问题及其背后的原理。 ... [详细]
  • 本文将详细介绍如何在ThinkPHP6框架中实现多数据库的部署,包括读写分离的策略,以及如何通过负载均衡和MySQL同步技术优化数据库性能。 ... [详细]
  • 当面临数据库清理任务时,若无删除或重建数据库的权限,可以通过编写SQL脚本来实现批量删除用户自定义的数据表和存储过程。本文将详细介绍如何构造这样的SQL脚本。 ... [详细]
  • 深入分析十大PHP开发框架
    随着PHP技术的发展,各类开发框架层出不穷,成为了开发者们热议的话题。本文将详细介绍并对比十款主流的PHP开发框架,旨在帮助开发者根据自身需求选择最合适的工具。 ... [详细]
  • 深入理解SQL Server中的聚集与非聚集索引
    本文探讨了SQL Server数据库中两种主要的索引类型——聚集索引和非聚集索引,通过对比分析它们的特点及应用场景,旨在帮助读者更好地理解和利用这两种索引以优化查询性能。 ... [详细]
  • 2017年苹果全球开发者大会即将开幕,预计iOS将迎来重大更新,同时Siri智能音箱有望首次亮相,AI技术成为大会焦点。 ... [详细]
  • 本文探讨了大型服务端开发过程中常见的几个误区,包括异步任务处理不当、日志同步模式使用、网络操作未设置超时、缓存命中率及响应时间未统计、单一缓存模式、分布式缓存加锁不当以及团队管理上的误区,旨在帮助开发者避免这些常见错误。 ... [详细]
  • 本文介绍如何在Laravel框架中集成微信支付功能,包括如何配置微信支付环境、处理支付请求及接收支付回调等关键步骤。 ... [详细]
  • 推荐两款实用的网络诊断工具
    大家好,因为一些私事很久没有更新博客了。今天向大家介绍两款非常有用的网络诊断工具——Tracert和Telnet,帮助你更好地理解和解决网络问题。 ... [详细]
  • 在Java应用程序开发过程中,FTP协议被广泛用于文件的上传和下载操作。本文通过Jakarta Commons Net库中的FTPClient类,详细介绍如何实现文件的上传和下载功能。 ... [详细]
  • 三菱PLC SLMP协议报文详解
    本文详细解析了三菱PLC中使用的SLMP协议报文结构,包括其工作原理、通信流程及报文格式,旨在帮助工程师和技术人员更好地理解和运用这一协议。 ... [详细]
  • 使用C# .NET构建UDP点对点聊天应用
    本文详细介绍如何利用C# .NET框架开发一个基于UDP协议的点对点聊天程序,包括客户端与服务器之间的连接建立、数据传输等核心功能。 ... [详细]
  • 本指南详细介绍了如何在同一台计算机上配置多个GitHub账户,并使用不同的SSH密钥进行身份验证,确保每个账户的安全性和独立性。 ... [详细]
  • 本文探讨了如何利用 Hibernate 进行高效的批量更新和删除操作,包括直接使用 Hibernate API 的方法及其局限性,以及如何通过 JDBC 或存储过程实现更优的性能。 ... [详细]
author-avatar
mobiledu2502916313
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有