Oracle教程:重做日志文件基本维护

来源:这里教程网 时间:2026-02-27 13:24:00 作者:

重做日志文件最重要的用途就是用来恢复数据(其实你也可以用来logminer),它记录着system global area(sga)当中的database bu

重做日志文件最重要的用途就是用来恢复数据(其实你也可以用来logminer),它记录着system global area(sga)当中的database buffer cache(高速缓存区)的所有变更信息,记录到log buffer;不过在某些特殊情况下比如sqlldr direct等直接写入操作例外,这些例外将不会被记录。因此,使用redo log在实例崩溃情况下来恢复尚未写入数据文件的的数据。
针对每个实例,只有一个写进程lgwr;重做日志文件建议至少两个组,每个组至少两个成员文件,同一个组内的成员之间是内容相同的副本拷贝,同组内的成员大小保持一致,当然建议所有的成员大小都一致,为了避免相关的lgwr等待影响数据库性能,一个比较有用的建议是将成员文件在物理磁盘上分散存放。
提到重做日志文件不得不提到重做日志缓存区log buffer,以及一个重要的进程lgwr日志写进程,该进程负责建log buffer的内容写入到redo logfile,具体的触发条件如下:
◆ 当发出commit命令的时候
◆ 当log buffer的空间写满到1/3的时候或者当log buffer的空间写满1mb的记录的时候
◆ 当每3秒钟超时的时候
◆ 当dbwn需要写入数据文件的操作之前的时候
◆ 当切换日志文件的时候
0. 查看日志文件
select group#, sequence#, bytes, members, status  from v$log;--组号、序列号、大小、成员数量、状态【unused-从未使用过;current-当前使用中;active-活动的,,进行恢复的使用将会被用到;inactive-非活动的;clearing_current-正在清除当前日志文件中已经关闭的线程;clearing-类似的,在执行alter database clear logfile之后将被清空为空日志之后将转化为unused】
select * from v$logfile;--状态【invalid-该文件不可访问;stale-该文件内容不完全,比如正在添加一个文件成员;deleted-该文件不再被使用;空白-正在使用】
select groups, current_group#, sequence# from v$thread;--组数量、当前组、序列号
1. 查看log buffer
show parameter log_buffer
伴随着重做日志而来的还有一个重要的信息,那就是是否将日志文件进行归档。数据库可以运行在归档模式(archivelog)和非归档模式(noarchivelog)下。
2. 查看归档模式
archive log list;
select log_mode from v$database;
select archiver from v$instance;
3. 归档方式切换
为了简单,这里使用oracle 10g来演示。
sql*plus: release 10.2.0.5.0 - production on tue may 8 15:49:39 2012

copyright (c) 1982, 2010, oracle.  all rights reserved.


connected to:
oracle database 10g enterprise edition release 10.2.0.5.0 - 64bit production
with the partitioning, olap, data mining and real application testing options

sql> archive log list;
database log mode           no archive mode
automatic archival           disabled
archive destination           /u01/oracle/10g/arch
oldest online log sequence     158
current log sequence           160
--目前未归档,我们要切换为归档,首先设置归档目录
sql> alter system set log_archive_dest_1='location=/u01/oracle/10g/arch' scope=spfile;

system altered.
--关闭数据库
sql> shutdown immediate;
database closed.
database dismounted.
oracle instance shut down.
--启动实例mount状态
sql> startup mount;    
oracle instance started.

total system global area 1610612736 bytes
fixed size            2096632 bytes
variable size          469762568 bytes
database buffers     1124124073472 bytes
redo buffers           14680064 bytes
database mounted.
--打开归档模式
sql> alter database archivelog;

database altered.
--打开数据库
sql> alter database open;

database altered.
--检查归档模式
sql> archive log list;
database log mode           archive mode
automatic archival           enabled
archive destination           /u01/oracle/10g/arch
oldest online log sequence     158
next log sequence to archive   160
current log sequence           160

--手工切换日志文件
sql> archive log list;
database log mode           archive mode
automatic archival           enabled
archive destination           /u01/oracle/10g/arch
oldest online log sequence     159
next log sequence to archive   161
current log sequence           161
sql> alter system switch logfile;

system altered.

sql> archive log list;
database log mode           archive mode
automatic archival           enabled
archive destination           /u01/oracle/10g/arch
oldest online log sequence     160
next log sequence to archive   162
current log sequence           162

sql> alter system archive log current;

system altered.

sql> archive log list;
database log mode           archive mode
automatic archival           enabled
archive destination           /u01/oracle/10g/arch
oldest online log sequence     161
next log sequence to archive   163
current log sequence           163


--切换为非归档模式
sql> shutdown immediate;
database closed.
database dismounted.
oracle instance shut down.
sql> startup mount;
oracle instance started.

total system global area 1610612736 bytes
fixed size            2096632 bytes
variable size          469762568 bytes
database buffers     1124124073472 bytes
redo buffers           14680064 bytes
database mounted.
sql> alter database noarchivelog;

database altered.

sql> alter database open;

database altered.

sql> archive log list;
database log mode           no archive mode
automatic archival           disabled
archive destination           /u01/oracle/10g/arch
oldest online log sequence     158
current log sequence           160

相关推荐