最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
为什么Oracle 11g RMAN进行恢复时提示需要更多归档日志
时间:2026-06-17 08:45:52 编辑:袖梨 来源:一聚教程网
RMAN报“archived log not found”根本原因是控制文件未记录磁盘上存在的归档日志,常见于手动删除归档后未同步元数据、归档路径变更未重新catalog、RAC实例未全部mounted导致跨线程归档不可见,或recover until time/scn因按[FIRST_TIME, NEXT_TIME)区间判断而停在错误位置。
这是rman在recover阶段发现归档日志链断裂或未覆盖目标scn的明确信号,不是误报,而是恢复无法继续的准确判断。
RMAN报“archived log not found”但磁盘上有文件
常见错误现象是执行 RECOVER DATABASE 时提示 archived log not found,而你确认 /u01/arch/ 下确实存在对应 sequence# 的归档文件(如 1_100_1234567890.dbf)。根本原因不是文件丢失,而是控制文件没记录它。
- 手动删除归档后未运行
CROSSCHECK ARCHIVELOG ALL,导致 RMAN 仍认为这些文件已过期(EXPIRED),直接跳过读取 - 归档路径被修改过(如从
/u01/arch改为/u02/arch),但旧归档未用CATALOG START WITH重新注册 - 归档是
.gz压缩格式,RMAN 默认忽略,必须先gunzip解压再catalog - 使用了
BACKUP ARCHIVELOG ALL DELETE INPUT,但后续又手工清过目录,控制文件元数据与磁盘状态彻底脱节
RECOVER UNTIL TIME / SCN 导致“假成功”
执行 RECOVER DATABASE UNTIL TIME '2026-06-05 14:22:00' 后 RMAN 返回 SUCCESS,但紧接着 ALTER DATABASE OPEN RESETLOGS 就报 ORA-01194 —— 这说明恢复停在了错误位置。
- RMAN 按归档日志的
FIRST_TIME判断是否覆盖目标时间,实际应用的是整个日志覆盖区间[FIRST_TIME, NEXT_TIME)。若最后一个归档的NEXT_TIME是14:22:03,它就会被全量应用,停在14:22:03而非你指定的14:22:00 -
UNTIL SCN同理:RMAN 只检查归档日志头中的FIRST_CHANGE#和NEXT_CHANGE#,不精确截断到某个事务内 - 真正想停在精确时间点,得用
RECOVER DATABASE UNTIL CANCEL,然后手动输入AUTO让 Oracle 自动选日志,直到提示Media recovery complete或Specify log时再中断
RAC环境跨节点归档不可见
在两节点 RAC 中执行 LIST ARCHIVELOG ALL,只看到 THREAD# = 1 的归档,THREAD# = 2 完全为空,即使共享存储中 +FRA/orcl/archivelog/2026_06_05/ 下有 node2 生成的归档文件。
-
V$ARCHIVED_LOG视图默认只聚合当前实例的归档元数据,不自动跨实例同步 - 必须所有实例都处于
MOUNTED状态(不能只启一个节点),再进 RMAN 执行RESYNC TARGET DATABASE - 连接 RMAN 时要用全局服务名(如
rman target sys/password@orcl),不能连单实例专用 TNS(如orcl1) - 验证是否同步成功:
SELECT DISTINCT THREAD# FROM V$ARCHIVED_LOG应返回1和2;若只有一行,说明另一实例未参与广播或CLUSTER_DATABASE=FALSE被误设
归档空间满导致日志无法归档,进而阻断恢复链
当 db_recovery_file_dest_size 达到 99% 以上,ORA-19815 和 ORA-16014 出现,数据库无法生成新归档,老归档也无法被 RMAN 删除 —— 形成死锁。
- 手工删操作系统文件(
rm -f /u01/fast_recovery_area/*)完全无效,V$FLASH_RECOVERY_AREA_USAGE仍显示 100% 使用率 - 必须用 RMAN 清理:
CROSSCHECK ARCHIVELOG ALL→DELETE NOPROMPT EXPIRED ARCHIVELOG ALL→DELETE NOPROMPT ARCHIVELOG ALL COMPLETED BEFORE 'SYSDATE-7' - 如果归档已超
control_file_record_keep_time(默认约30天),控制文件里无记录,RMAN 无法识别,只能手工删,且绝对安全——它们对当前恢复无任何作用 - 临时扩容可解燃眉之急:
ALTER SYSTEM SET db_recovery_file_dest_size = 20G SCOPE=BOTH,无需重启
最常被忽略的点是:RMAN 从不还原在线 redo 日志,也从不依赖它们做介质恢复。所谓“需要更多归档”,本质是归档日志链在某个 SCN 断开,而这个断点可能藏在控制文件元数据缺失、RAC 实例未同步、或时间点计算逻辑里,而不是磁盘上少了一个文件。
相关文章
- 淘宝网页版直接入口 淘宝免除APP登录网址 06-18
- 通义千问企业版国内访问限制:账号、地区与网络条件说明 06-18
- 环外职业怎么选择 06-18
- 通义千问企业版入门要点:权限、收费与基础设置说明 06-18
- 通义千问入门需要了解什么?核心功能、场景与配置要点 06-18
- 明末渊虚之羽陆红柳怎么稳过 06-18