欢迎光临
我们一直在努力

重做日志管理


计算机操作的文件越大,系统的效率越低,因此,日志文件应该尽可能地小,但文件过小又会导致日志文件频繁切换,引发完全检查点,导致系统挂起

所谓的重做日志维护或修复,就是将有问题的重做日志组或日志成员删掉,之后再重建它们。可以操作重做日志组也可以操作成员,通常建议操作日志组。


添加日志组:


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 数据库以前的备份失效,所以接下来应该做一个全备份。

赞(0)
【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。