重做日志管理

来源:这里教程网 时间:2026-03-03 12:51:53 作者:

计算机操作的文件越大,系统的效率越低,因此,日志文件应该尽可能地小,但文件过小又会导致日志文件频繁切换,引发完全检查点,导致系统挂起 所谓的重做日志维护或修复,就是将有问题的重做日志组或日志成员删掉,之后再重建它们。可以操作重做日志组也可以操作成员,通常建议操作日志组。 添加日志组: SQL> ALTER DATABASE ADD LOGFILE ('/u01/app/oracle/onlinelog/redo_01a.log', '/u02/app/oracle/onlinelog/redo_01b.log') SIZE 100M; 删除日志组: SQL> ALTER DATABASE DROP LOGFILE GROUP 4; ASM 应用中为重做日志组添加新成员: 由于使用 ASM 自动管理文件,所以只需要指定 ASM 磁盘组,不需要指定文件路径和文件名,如果指定具体文件路径和文件名也是可以的 SQL> ALTER DATABASE ADD LOGFILE MEMBER '+ASM_RCY' REUSE TO GROUP 1; 如下图: online redolog 文件状态: 空白:表示该文件正在使用 stale:表示该文件中的内容是不完全的 invalid:表示该文件不可以被访问 deleted:表示该文件已不再有用了 删除日志成员: SQL> ALTER DTABASE DROP LOGFILE MEMBER '/u01/app/oracle/onlinelog/redo_01.log'; 不能删除当前组的成员,如果要删除,应先使用 ALTER SYSTEM SWITCH LOGFILE 命令进行切换; 如果要删除刚刚加入的状态为 invalid 的成员,正常的操作方法可能需要发若干个 ALTER SYSTEM SWITCH LOGFILE  命令多次进行切换,要等很久,比较快捷的方法是:先关闭数据库,在开启数据库,这时候就可以顺利删除了。 每个日志组至少有一个成员才能正常工作 清除 online redo logfile 有时不能用删除重建的方式来维护日志组,如:数据库中只有两个日志组或崩溃的日志文件属于当前日志组。在这种情况下,如果数据库是开启的话,由于一个联机日志文件崩溃使得归档活动不能正常进行,最终导致数据库被挂起。 此时可以使用如下命令来重新初始化联机重做日志文件: SQL> ALTER DATABASE CLEAR LOGFILE GROUP 组号; 如果崩溃的日志文件已经不能归档(组内所有成员都坏了),可以在以上命令中使用 UNARCHIVED 关键词来清除已崩溃的重做日志文件,从而避免对它们进行归档,其命令格式如下: SQL> ALTER DATABASE CLEAR UNARCHIVED LOGFILE GROUP 组号; 注:执行了以上命令中的任何一个,都将导致 Oracle 数据库以前的备份失效,所以接下来应该做一个全备份。

相关推荐