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 脚本闭环(可审计、可追踪)。

相关推荐
love530love1 小时前
解决微软登录错误 0xCAA82EE2 & 身份验证故障排查指南
运维·人工智能·microsoft·onedrive·microsoft 365·teams·microsoftonline
A.A呐1 小时前
【Linux第八章】环境变量
linux
数据知道1 小时前
MongoDB 逻辑查询运算符:$and, $or, $nor, $not 构建复杂逻辑组合
数据库·mongodb
m0_528749001 小时前
复杂一点的sql查询
数据库·sql
闲人编程1 小时前
聚合管道与复杂查询
开发语言·oracle·lua·match·查询·聚合·lookup
Zhu_S W2 小时前
EasyExcel动态表头详解
java·linux·windows
好记忆不如烂笔头abc2 小时前
不同 Oracle 版本的客户端/服务器互操作性支持矩阵
服务器·oracle·矩阵
Volunteer Technology2 小时前
Oracle数据DML语句和DQL语句
oracle
敲代码的哈吉蜂2 小时前
Nginx配置文件的管理及优化参数
java·服务器·nginx