oracle的主要文件类型有三种,分别是控制文件,数据文件和日志文件;日志文件记录了对数据库的所有操作记录,提供了一个恢复机制
oracle的主要文件类型有三种,分别是控制文件,数据文件和日志文件;日志文件记录了对数据库的所有操作记录,提供了一个恢复机制,oracle将数据写入数据文件之前,需要将修改过的内容写入redo日志文件,oracle推荐最少存在两个日志文件组,每个组中存在两个或更多的成员文件;lgwr进程根据日志组循环写,日志组的中的文件成员大小是一致的,并分配(lsn)log sequence number;当写满一个文件组的时候,oracle会触发一个log switch切换到另一个日志组,将lsn号码加一,同时引发check point,,dbwr进程将修改过的数据写入磁盘上的数据文件中;
触发lgwr的5个条件:
在一个事务提交之后
每三秒钟
当redo buffer cache三分之一满后
当redo buffer cache里面修改过的数据容量达到1m后
在dbwn进程将修改过的数据写入磁盘文件之前
sql> select group#,thread#,sequence#,archived,status from v$log; //查看日志组总数和当前active状态的日志组,当前为1
group# thread# sequence# arc status
---------- ---------- ---------- --- ----------------
1 1 46 no current
2 1 44 yes inactive
3 1 45 yes inactive
sql> alter system switch logfile; //手动触发一次日志切换
system altered.
sql> select group#,thread#,sequence#,archived,status from v$log; //可以看到当前active的日志组已经切换为2
group# thread# sequence# arc status
---------- ---------- ---------- --- ----------------
1 1 46 yes active
2 1 47 no current
3 1 45 yes inactive
如果lgwr进程工作很频繁,日志组很快就会被写满,这个时候就需要dbwn进程将修改过的数据写到数据文件中,否则oracle将无法正常工作,fast_start_mttr_target参数定义了dbwn进程在多少时间间隔内必须将redolog中的数据写入数据文件,单位为秒,这是个影响数据库性能的关键参数;
sql> show parameter fast_start;
name type value
------------------------------------ ----------- ------------------------------
fast_start_io_target integer 0
fast_start_mttr_target integer 0
fast_start_parallel_rollback string low
sql> alter system set fast_start_mttr_target=600 scope=both; //修改这个参数为600秒
system altered.
sql> show parameter fast_start_mttr_target;
name type value
------------------------------------ ----------- ------------------------------
fast_start_mttr_target integer 600