Oracle ASM归档日志自动清理:RMAN+crontab一键闭环(生产可用)

1. 背景:为什么要做归档自动清理

  • 归档日志(ARCHIVELOG)长期积累会把 ASM/FRA 顶满

  • 空间满了会引发:归档写不进去 → 业务卡顿/停摆 → 典型生产事故链

  • 最好的方式不是手工删,而是策略化 + 自动化 + 可审计日志

2. 目标与策略(本文采用)

  • 保留归档:14 天(RETENTION_DAYS=14)

  • 对账窗口:20 天(CROSSCHECK_DAYS=20,轻量但够用)

  • 每天低峰自动执行:05:00

  • 日志保留 30 天自动清理

提醒:如果有 ADG/备库/闪回还原点,清理口径要更谨慎(本文按"单库/不依赖备库追归档"场景写)。

3. 前置检查(只读,安全)

3.1 确认实例与环境

bash 复制代码
su - oracle
. ~/.bash_profile 2>/dev/null || true
echo $ORACLE_SID
echo $ORACLE_HOME
which rman

3.2(可选)确认归档模式

sql 复制代码
-- sqlplus / as sysdba
archive log list;

4. 落地步骤(从创建文件夹开始)

4.1 创建目录

sql 复制代码
su - oracle
mkdir -p /home/oracle/rman/log

4.2 创建"模板化"脚本(建议用这一版,改变量就行)

保存为:/home/oracle/rman/arch_cleanup.sh

  • ORACLE_SID:告诉 Oracle 客户端"你要连哪个实例"(RAC 时尤其重要)

  • ORACLE_HOME:告诉系统 Oracle 软件装在哪(rman/sqlplus 等命令在哪)

  • PATH :把 $ORACLE_HOME/bin 加到命令搜索路径里,保证脚本里直接执行 rman 能找到正确版本

bash 复制代码
cat > /home/oracle/rman/arch_cleanup.sh <<'EOF'
#!/bin/bash
set -euo pipefail

# ===== 可配置区:以后换库就改这里 =====
export ORACLE_SID="yjxt2"
export ORACLE_HOME="/u01/app/oracle/product/19.3.0/db"
export PATH="$ORACLE_HOME/bin:$PATH"

RETENTION_DAYS=14       # 保留天数:14
CROSSCHECK_DAYS=20      # 对账窗口:建议 >= RETENTION_DAYS
LOG_KEEP_DAYS=30        # 日志保留天数

BASE="/home/oracle/rman"
LOGDIR="$BASE/log"
mkdir -p "$LOGDIR"
LOG="$LOGDIR/arch_cleanup_$(date +%F_%H%M%S).log"

echo "=== $(date '+%F %T') START archivelog cleanup ===" | tee -a "$LOG"
echo "ORACLE_SID=$ORACLE_SID ORACLE_HOME=$ORACLE_HOME" | tee -a "$LOG"

RMAN_BLOCK=$(cat <<RMAN
RUN{
  CROSSCHECK ARCHIVELOG FROM TIME "SYSDATE-${CROSSCHECK_DAYS}";
  DELETE NOPROMPT EXPIRED ARCHIVELOG ALL;
  DELETE NOPROMPT ARCHIVELOG ALL COMPLETED BEFORE "SYSDATE-${RETENTION_DAYS}";
}
RMAN
)

# 生产降噪:低 CPU/IO 优先级
if command -v ionice >/dev/null 2>&1; then
  ionice -c2 -n7 nice -n 15 rman target / msglog "$LOG" append <<<"$RMAN_BLOCK"
else
  nice -n 15 rman target / msglog "$LOG" append <<<"$RMAN_BLOCK"
fi

echo "=== $(date '+%F %T') END archivelog cleanup ===" | tee -a "$LOG"

# 日志自动清理(避免撑爆 /home)
find "$LOGDIR" -type f -name "arch_cleanup_*.log" -mtime +${LOG_KEEP_DAYS} -delete
EOF

chmod 750 /home/oracle/rman/arch_cleanup.sh

4.3 手工跑一次验证

bash 复制代码
/home/oracle/rman/arch_cleanup.sh
ls -t /home/oracle/rman/log/arch_cleanup_*.log | head -1
tail -n 120 "$(ls -t /home/oracle/rman/log/arch_cleanup_*.log | head -1)"

4.4 配置 crontab(每天 05:00)

bash 复制代码
crontab -e

加入:

bash 复制代码
0 5 * * * /home/oracle/rman/arch_cleanup.sh >/dev/null 2>&1

验证:

bash 复制代码
crontab -l

5. 验收方法

5.1 看日志是否每天生成

bash 复制代码
ls -ltr /home/oracle/rman/log/ | tail

5.2 看 ASM 归档目录是否在滚动保留

bash 复制代码
su - grid
asmcmd ls +ARCH/YJXT/ARCHIVELOG | head
asmcmd ls +ARCH/YJXT/ARCHIVELOG | tail

6. 常见坑

  1. RMAN 用 control file 当仓库会"失忆"

    归档记录被覆盖后,RMAN 可能列不出历史归档,导致"删不到 ASM 旧文件"。

    解决:尽量用自动化持续清理,必要时引入 recovery catalog。

  2. CROSSCHECK ALL 会越来越慢

    归档越多越慢,所以用 FROM TIME "SYSDATE-xx" 缩窗。

  3. 别把 asmcmd rm 当日常

    手工删适合救火;日常要走 RMAN 脚本闭环(可审计、可追踪)。

相关推荐
supersolon5 分钟前
Windows下WSL(Ubuntu24.04)安装Nodejs
linux·ubuntu·node.js
NineData21 分钟前
杭州 OpenClaw 开发者聚会来了!NineData 叶正盛将带来主题分享
数据库·人工智能
进击切图仔1 小时前
跨系统时间戳同步问题解决总结
linux
Benszen1 小时前
Docker容器化解决方案全解析
运维·docker·容器
badhope1 小时前
Docker从零开始安装配置全攻略
运维·人工智能·vscode·python·docker·容器·github
wang2455981991 小时前
【MySQL基础篇】概述及SQL指令:DDL及DML
sql·mysql·oracle
wsoz2 小时前
文件IO讲解
linux·嵌入式
mounter6252 小时前
基于MLX设备的Devlink 工具全指南与核心架构演进
linux·运维·服务器·网络·架构·kernel
wefg12 小时前
【计算机网络】网络基础 - 1(网络协议/TCP/IP协议栈/局域网内外数据传输/数据封装、解包、分用)
linux·服务器·网络