Oracle11G配置归档模式

在DBA部署数据库之初,必须要做出的最重要决定之一就是选择归档模式(ARCHIVELOG)或者非归档模式(NOARCHIVELOG )下运行数据库。我们知道,Oracle 数据库需要至少两组联机日志,每当一组联机日志写满后会发生日志切换,继续向下一组联机日志写入。如果是归档模式,日志切换会触发归档进程 (ARCn)进行归档,生成归档日志。Oracle 保证归档完成前,联机日志不会被覆盖,如果是非归档模式, 则不会触发归档动作。Oracle归档模式是ORACLE热备份的必要条件,特别是7X24生产数据库,必须要工作在归档模式。

1、归档模式的优缺点

归档日志文件中保留了数据库的改动信息,在这种模式下可以获得如下好处:
可以进行完全、不完全恢复:由于对数据库所做的全部改动都记录在日志文件中,如果发生硬盘故 障等导致数据文件丢失的话,则可以利用物理备份和归档日志完全恢复数据库,不会丢失任何数据。
可以进行联机热备:所谓联机热备,就是在数据库运行状态下,对数据库进行备份。备份时用户对 数据库的使用不受任何影响。
可以实施 Data Guard:可以部署 1 个或多个备用数据库,从而最大限度地提供灾难保护手段。
可以实施 Stream:利用 Stream 技术,可以实现最简单的单向复制到复杂的双向复制、多向复制,提供更加灵活的数据冗余方案。
表空间可以脱机:可以备份部分数据库,比如重要的表空间。
能够增量备份:只需做一次完全备份,以后只备份发生改变的数据,可以提高备份速度。
更多的优化选项:随着 Oracle 版本升级,在联机热备方面不断有新的优化策略出现。
使用归档模式的缺点在于,需要更多的磁盘空间保存归档日志;DBA 会有更多的管理工作,包括维护归档空间、备份归档日志。

2、非归档模式的优缺点

非归档模式不生成归档日志,从数据安全角度来说,这种模式缺点是主要的,而优点可以忽略不计。非归档模式的缺点包括:
只能脱机备份:只能进行脱机备份,也就是所谓的“ 冷备份”,和联机备份的“ 热备份” 相对应,数据库必须完全 关闭后备份,在备份过程中数据库不可用;
必须完全备份:必须备份整个数据库,不能只备份部分数据库;
不能增量备份:不能增量备份对于 TB 级数据库(VLDB) ,这是一个非常大的缺点;
只能部分恢复:如果数据文件丢失需要恢复,DBA 只能恢复最后一次的完全备份,而之后的所有 数据库改变全部丢失。

非归档模式的优点包括:DBA 的管理工作减少,因为非归档模式不产生归档日志,因此 DBA 不用考虑对归档的管理;性能会有提升。

3、非归档模式转换成归档模式

数据库创建过程中需要指定归档和非归档模式,如果选择的是非归档模式,可以在数据库创建完成后手工改变成归档模式,具体操作步骤如下:

# 查看数据库是否处于归档模式
select name, log_mode from v$database;
注:log_mode的值为 NOARCHIVELOG 表示数据库处于非归档模式;log_mode的值为 ARCHIVELOG 表示数据库处于归档模式。

# 查看数据库的归档信息(此方法需要 as sysdba)
archive log list;

注:Database log mode 的值为 No Archive Mode;Automatic archival 的值为 Disabled;表示当前数据库处于非归档模式。Database log mode 的值为 Archive Mode;Automatic archival 的值为 Enabled;表示数据库已开启归档模式。

# 关闭数据库
shutdown immediate;

# 启动数据库到mount状态
startup mount;

img

# 修改数据库为归档模式
alter database archivelog;

# 打开数据库
alter database open;

# 查询数据库是否处于归档模式
archive log list;

img

当前数据库已经由非归档模式变更为归档模式、我们还需要执行修改日志文件命名格式、更改日志文件路径等操作:

# 修改日志文件命名格式
alter system set log_archive_max_processes = 5; 
alter system set log_archive_format = "archive_%t_%s_%r.log" scope=spfile;

# 更改日志文件路径
alter system set log_archive_dest_1='location=D:/app/Administrator/archivelog/orcl'; 
此时 Archive destination 的值更改为 D:/app/Administrator/archivelog/orcl
该语句含义是确定归档日志的路径,实际上Oracle 10g以后可以生成多份一样的日志,保存多个位置,以防不测。
注:这里的文件路径必须真实存在。
例如再添加一个日志位置可使用以下语句:
alter system set log_archive_dest_2='location=/bak/orcl/archive_log';

配置完归档模式以后我们可以立即执行归档重做日志:

# 查看当前被归档的重做日志
select name from v$archived_log;

# 强制切换日志格式
alter system switch logfile

# 归档当前的重做日志
alter system archive log current;

注意:
1、如果没有重启数据库,归档日志的文件格式仍然会是默认的格式.dbf。
2、alter system switch logfile 是强制日志切换,不一定就归档当前的重做日志文件(若自动归档打开,就归档前的重做日志,若自动归档没有打开,就不归档当前重做日志。
3、alter system archive log current 是归档当前的重做日志文件,不管自动归档有没有打都归档。 主要的区别在于:alter system switch logfile 对单实例数据库或RAC中的当前实例执行日志切换; alter system archive log current 会对数据库中的所有实例执行日志切换。

# 重启数据库
shutdown immediate;
startup

# 查询归档信息
archive log list;

此时我们到刚才的 D:/app/Administrator/archivelog/orcl 路径下面去查看是否已经生成了归档日志:

img

4、归档模式转换成非归档模式

数据库从非归档模式更改为归档模式需要数据库处于mount状态下, 如果数据库处于打开状态则需要先关闭数据库,如果数据库处于关闭状态:

# 关闭数据库之前归档当前重做日志
alter system archive log current;

# 关闭数据库
shutdown immediate;

# 启动数据库到mount状态
startup mount;

# 查看数据库的归档信息
archive log list;
或者执行下面的操作
select name, log_mode from v$database;select name, log_mode from v$database;

img

# 更改归档模式为非归档模式
alter database noarchivelog;

# 查看数据库的归档信息
archive log list;
或者执行下面的操作
select name, log_mode from v$database;select name, log_mode from v$database;

# 打开数据库
alter database open;

# 验证
select name, log_mode from v$database;

img

推荐文章