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

相关推荐
Gofarlic_oms14 小时前
利用API实现ANSYS许可证管理自动化集成
运维·服务器·开发语言·matlab·自动化·负载均衡
档案宝档案管理5 小时前
权限分级管控,全程可追溯,筑牢会计档案安全防线
运维·网络·人工智能
ss2736 小时前
食谱推荐系统功能测试如何写?
java·数据库·spring boot·功能测试
l1t6 小时前
DeepSeek总结的数据库外部表
数据库
m0_674294646 小时前
如何编写SQL存储过程性能对比_记录执行时间评估优化效果
jvm·数据库·python
倔强的石头1067 小时前
【Linux指南】基础IO系列(八):实战衔接 —— 给微型 Shell 添加完整重定向功能
linux·运维·服务器
try2find7 小时前
打印ascii码报错问题
java·linux·前端
014-code7 小时前
CompletableFuture 实战模板(超时、组合、异常链处理)
java·数据库
运气好好的7 小时前
怎样开启phpMyAdmin的操作审计日志_记录每条执行的SQL
jvm·数据库·python
观北海7 小时前
AiScan-N:AI全自动化渗透测试工具的深度技术解析
运维·自动化