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

相关推荐
尤老师FPGA1 天前
petalinux修改设备树添加vdma生成linux系统
android·linux·运维
yxy___1 天前
达梦分布式集群DPC_重做副本-操作指南(DEM)_yxy
运维·分布式
月山知了1 天前
linux kernel component子系统:基于rk3588 Android 14 kernel-6.1 display-subsystem代码分析
android·linux·运维
星辰徐哥1 天前
大模型工程化部署:Docker Compose批量部署
运维·docker·容器
SEO-狼术1 天前
Support Network Diagnostics in .NET
运维·服务器·网络
入瘾1 天前
etcd 显示连接失败
数据库·chrome·etcd
AI周红伟1 天前
AI自动盯盘与定时行情分析:OpenClaw股票辅助Agent集成完整使用指南-周红伟
运维·服务器·人工智能·音视频·火山引擎
本体智能1 天前
预制指标、宽表、SQL、本体ABC:真正决定长期成本的,是一次变更会波及多少层
数据库·sql·本体神经网络·uino数据智能引擎
长安11081 天前
数据库基础知识----数据库大观
数据库·oracle
不才小强1 天前
Linux系统常用命令
linux·运维·网络