Oracle RMAN 归档日志清理标准流程:CROSSCHECK / EXPIRED / SYSDATE-N

================================

Oracle 归档日志(ArchiveLog)清理 SOP(RMAN 优先,ASM 仅应急)

适用:单机 / RAC,ASM(+RECO)/文件系统。生产建议走 RMAN,避免"目录记录"和"实际文件"不一致。

================================

1) 切换 Oracle 用户

su - oracle

2) 选定要操作的实例/数据库(RAC 里一定要对准:例如 UTF8CDB1)

export ORACLE_SID=UTF8CDB1

3) 进入 RMAN

rman target /

4) 校验归档记录 vs 实际文件(缺失的标记为 EXPIRED)

作用:RMAN/控制文件里有记录,但磁盘/ASM 上文件已经不存在 -> 标记为 EXPIRED(对账用)

CROSSCHECK ARCHIVELOG ALL;

5) 清理 EXPIRED(清控制文件里的"死记录",通常不释放 FRA 空间)

作用:只删 RMAN 目录/控制文件记录;EXPIRED 文件本来就不在了,所以通常不会"腾空间"

DELETE NOPROMPT EXPIRED ARCHIVELOG ALL;

6) 删除 N 天前归档(真正删除文件、释放空间的主要动作)

作用:删除"完成时间早于 SYSDATE-N"的归档文件

安全条件:只删"已备份过 1 次到磁盘"的归档,避免误删恢复链路

备注:SYSDATE-N 里 N 可以为 0,但生产不建议用 0(容易把归档几乎清空,风险大)

DELETE NOPROMPT ARCHIVELOG ALL COMPLETED BEFORE 'SYSDATE-3'

BACKED UP 1 TIMES TO DEVICE TYPE DISK;

退出 RMAN

EXIT;

================================

什么时候才考虑用 ASM 直接清?(把它当应急按钮)

================================

1) FRA/RECO 爆满到影响业务(归档写不进去,业务可能受影响甚至挂库)

2) RMAN 删除被卡住(文件被占用、报错删不了)

3) 需要先"抢救一点空间"让系统恢复呼吸

注意:ASM 直接删除是"绕过 RMAN 目录"的,删完会造成控制文件记录与实际文件不一致,

所以必须做收尾对账,否则后续备份/清理/排障会更难看。

================================

如果已经/必须用 ASM 删:正确收尾姿势(对账 + 清垃圾记录)

================================

仍然用 RMAN 做"对账 + 清 EXPIRED 记录"

rman target / <<'EOF'

CROSSCHECK ARCHIVELOG ALL;

DELETE NOPROMPT EXPIRED ARCHIVELOG ALL;

EXIT;

EOF

相关推荐
Avan_菜菜15 小时前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
Nturmoils20 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波1 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
SelectDB2 天前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
倔强的石头_2 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
zzzzzz3103 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
XIAOHEZIcode3 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
用户0328472220704 天前
如何搭建本地yum源(上)
运维
倔强的石头_5 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab5 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm