这篇文章主要介绍Redo丢失怎么处理,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
一.说明:
1.以下所说的当前日志指日志状态为CURRENT,ACTIVE,非当前日志指日志状态为INACTIVE
2.不用考虑归档和非归档模式,2种模式下的Redo丢失情况一样。
二.丢失Redo的4种情况:
第一种情况:非当前日志,正常关闭。
第二种情况:非当前日志,非正常关闭。
第三种情况:当前日志,正常关闭。
第四种情况:当前日志,非正常关闭。
三.处理方法:
第一、二种情况的处理方法一样,直接把日志文件clear即可。
SQL> alter database clear logfile group 3;
SQL> alter database clear unarchived logfile group 3;//如果INACTIVE状态的在线Redo还未归档,增加关键字unarchived完成clear操作。(ACTIVE,INACTIVE都有可能未完成归档,归档是否完成可以查看v$log.archived字段)。例子:
SQL> startup mountORACLE 例程已经启动。
Total System Global Area 263639040 bytesFixed Size 1384012 bytesVariable Size 167772596 bytesDatabase Buffers 88080384 bytesRedo Buffers 6402048 bytes数据库装载完毕。
SQL> select group#,thread#,status,archived from v$log;
GROUP# THREAD# STATUS ARCHIV———- ———- ——————————– —— 1 1 CURRENT NO 3 1 ACTIVE NO 2 1 INACTIVE YES
SQL> alter database clear logfile group 3;alter database clear logfile group 3*第 1 行出现错误:ORA-01624: 日志 3 是紧急恢复实例 orcl (线程 1) 所必需的ORA-00312: 联机日志 3 线程 1: ‘E:APPORADATAORCLREDO03.LOG’
SQL> alter database clear logfile group 2;
数据库已更改。
第三种情况的处理办法:
SQL>startup mount;
SQL>recover database until cancel;
SQL>alter database open resetlogs;
例子1:
SQL> shutdown immediate免费主机域名
数据库已经关闭。已经卸载数据库。ORACLE 例程已经关闭。
SQL> startup mount
ORACLE 例程已经启动。Total System Global Area 263639040 bytesFixed Size 1384012 bytesVariable Size 167772596 bytesDatabase Buffers 88080384 bytesRedo Buffers 6402048 bytes数据库装载完毕。
SQL> alter database open resetlogs;
alter database open resetlogs*第 1 行出现错误:ORA-01139: RESETLOGS 选项仅在不完全数据库恢复后有效SQL> recover database until cancel;
完成介质恢复。
SQL> alter database open resetlogs;
数据库已更改。
例子2(第三种情况的第二个处理方法):
SQL> shutdown immediate
数据库已经关闭。已经卸载数据库。ORACLE 例程已经关闭。
SQL> startup mount
ORACLE 例程已经启动。
Total System Global Area 263639040 bytesFixed Size 1384012 bytesVariable Size 免费主机域名 167772596 bytesDatabase Buffers 88080384 bytesRedo Buffers 6402048 bytes数据库装载完毕。
SQL> select group#,thread#,status,archived from v$log;
GROUP# THREAD# STATUS ARCHIV———- ———- ——————————– —— 1 1 CURRENT NO 3 1 INACTIVE YES 2 1 INACTIVE YES
SQL> alter database clear logfile group 2;
数据库已更改。
SQL> alter database clear logfile group 3;
数据库已更改。
SQL> alter database clear unarchived logfile group 1;
数据库已更改。 这里CURRENT的Redo日志文件组能被clear unarchived。
SQL> alter database open;
数据库已更改。
如果Redo日志文件丢失,clear操作完成之后将在原有位置创建新的Redo日志文件。
第四种情况的处理方法:1.通过备份来还原、恢复数据。
2.通过修改参数文件中的参数
_allow_resetlogs_corruption=TRUE
来强制启动数据库。
四.验证数据库是否正常关闭的方法
SQL> select open_mode from v$database;OPEN_MODE——————–READ WRITE
SQL> select status from v$instance;STATUS————OPEN
SQL> select file#,checkpoint_change#,fuzzy from v$datafile_header; FILE# CHECKPOINT_CHANGE# FUZ———- —————— — 1 1165820 YES 2 1165820 YES 3 1165820 YES 4 1165820 YES FUZZY bit in datafile header means that there may have been writes into a datafile after the last checkpoint. E.g. there may be changes written to datafile with higher SCN than checkpoint_change# stored in datafile header (seen from v$datafile_header.checkpoint_change#).
FUZYY表示模糊性,意思是,该数据文件处于模糊状态,在最近一次CHECKPOINT后,该文件上的数据可能被修改过了,但没来得及更新到该文件上(或者该文件不知道),需要读取日志信息来判断。
SQL> select file#,checkpoint_change#,last_change# from v$datafile; FILE# CHECKPOINT_CHANGE# LAST_CHANGE#———- —————— ———— 1 1165820 2 1165820 3 1165820 4 1165820 由于数据库是打开的状态,所以终止SCN是空,SCN的内容可参考文章:http://space.itpub.net/23135684/viewspace-627343
SQL> shutdown immediate
数据库已经关闭。已经卸载数据库。ORACLE 例程已经关闭。
SQL> startup mount
ORACLE 例程已经启动。Total System Global Area 313860096 bytesFixed Size 1384352 bytesVariable Size 155189344 bytesDatabase Buffers 150994944 bytesRedo Buffers 6291456 bytes数据库装载完毕。
SQL> select file#,checkpoint_change#,fuzzy from v$datafile_header;
FILE# CHECKPOINT_CHANGE# FUZ———- —————— — 1 1166324 NO 2 1166324 NO 3 1166324 NO 4 1166324 NO 在正常管理数据库的情况下,FUZZY字段都应该是NO,表示没有模糊不清的SCN存储在数据文件中。
SQL> select file#,checkpoint_change#,last_change# from v$datafile;
FILE# CHECKPOINT_CHANGE# LAST_CHANGE#———- —————— ———— 1 1166324 1166324 2 1166324 1166324 3 1166324 1166324 4 1166324 1166324
正常关闭数据库的终止SCN应该和启动SCN相同。FUZZY等于NO,且数据库的终止SCN等于启动SCN等于数据文件SCN,那么可以认为数据库是正常关闭,且在打开数据库之前不需要执行实例恢复或Crash恢复。
SQL> alter database open;
数据库已更改。
SQL> shutdown abort
ORACLE 例程已经关闭。
SQL> startup mount
ORACLE 例程已经启动。Total System Global Area 313860096 bytesFixed Size 1384352 bytesVariable Size 155189344 bytesDatabase Buffers 150994944 bytesRedo Buffers 6291456 bytes数据库装载完毕。
SQL> select file#,checkpoint_change#,fuzzy from v$datafile_header; FILE# CHECKPOINT_CHANGE# FUZ———- —————— — 1 1166327 YES 2 1166327 YES 3 1166327 YES 4 1166327 YES 非正常关闭数据库实例,FUZZY字段的值是YES。
SQL> select file#,checkpoint_change#,last_change# from v$datafile;
FILE# CHECKPOINT_CHANGE# LAST_CHANGE#———- —————— ———— 1 1166327 2 1166327 3 1166327 4 1166327 非正常关闭数据库实例,终止SCN依然为空。那么,在数据库被打开之前必须使用归档Redo日志完成实例恢复或Crash恢复。
以上是“Redo丢失怎么处理”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注云技术行业资讯频道!
小编给大家分享一下数据库中如何修改自动收集统计信息任务的执行时间,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! 一般情况,oracle11G数据库自动收集统计信息任务的设置如下:1、Oracle11g 的默认设置;2、user_tab_mod…