oracle归档模式 日志限制,Oracle数据库对日志的管理模式有两种非归档模式和归档模式...

一、日志操作模式

Oracle数据库对日志的管理模式有两种,即:非归档模式和归档模式。在建立或安装Oracle数据库时,如果没有指定日志操作模式,则默认为非归档模式(NOARCHIVELOG)。数据库建立之后,用户可以根据需要修改数据库日志的操作模式。

1.非归档模式(NOARCHIVELOG)

非归档模式是指不保存重做日志的日志操作模式,这种日志操作模式只能用于保护实例失败(如系统断电),而不能用于保护介质失败(数据库物理文件损坏)。

非归档模式的工作过程如下:假设数据库只有两个日志组,且当前日志组为日志组一,日志序列号为1。当事务变化填满日志组一时,系统会切换到日志组二,并且LGWR进程将事务变化写入该日志组,日志序列号变为2;而当事务变化填满日志组二时,系统又自动切换回日志组一,此时日志序列号变为3,并且日志序列号3所对应的事务变化会覆盖日志序列号1所对应的事务变化,依此类推。

2.归档模式(ARCHIVELOG)

归档模式是指将重做日志内容保存到归档日志中的日志操作模式。在这种日志操作模式下,当进行日志切换时ARCH进程会将重做日志的内容复制到归档日志中。例如,假设数据库只包含两个日志组,LGWR进程首先将事务变化写入日志组一,此时日志序列号为1;当事务变化填满日志组一时,系统将自动切换到日志组二,并将事务变化写入日志组二,此时日志序列号变为2,同时后台进程ARCn会将日志组一的内容保存到归档日志文件1中;而当事务变化填满日志组二时,系统自动切换回日志组一,并将事务变化写入日志组一,此时日志序列号变为3,同时后台进程ARCn会将日志组二的内容保存到归档日志文件2中,依此类推。

3.改变日志的操作模式为自动归档模式

①修改数据库的参数文件,在参数文件后添加如下参数:

log_archive_start = true

log_archive_dest_1 = "location=C:\Oracle\phj\archive"

log_archive_format = "T%TS%S.ARC"

说明:第一个参数在重启数据库时将自动启动ARCH进程;第二个参数指出归档日志存放的位置;第三个参数说明归档日志的文件名格式,%T取重做线程号,%S取日志序列号;

②重启并装载数据库

sqlplus internal/oracle@phj

shutdown immediate

startup mount pfile=%Oracle_Home%\database\initphj.ora

alter database archivelog

alter database open

4.生成归档日志

下面以分析TMP表的DDL和DML操作为例,介绍使用LogMiner分析重做日志和归档日志的全过程。我们首先执行以下语句在表TMP上执行DDL以及DML操作,并生成归档日志:

sqlplus internal/oracle@phj

create table tmp(name varchar2(10),no number(3));

alter system switch logfile;

insert into tmp values(‘liming’,112);

update tmp set no=200;

commit;

alter system switch logfile;

delete from tmp;

alter system switch logfile;

通过上面的操作会产生三个连续的归档日志文件。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值