oracle备份

bash 复制代码
#!/bin/bash
export PATH=/usr/bin:/bin
export LANG=en_US.UTF-8

# 待备份实例列表
ORACLE_SID_LIST="hx1 hxtest1 cdb1db11"
# 备份根路径
BACKUP_ROOT="/rmanbk"
# 生成时间目录:年月日_时分
TIME_DIR=$(date +%Y%m%d_%H%M)
BACKUP_DIR="${BACKUP_ROOT}/${TIME_DIR}"
# 日志目录与日志文件
LOG_DIR="${BACKUP_DIR}/logs"
LOG_FILE="${LOG_DIR}/backup.log"

# 初始化目录
mkdir -p "${BACKUP_DIR}" "${LOG_DIR}"

# Oracle 环境变量(正式环境原值)
export ORACLE_HOME="/u01/app/oracle/product/19.0.0.0/dbhome_1"
export PATH="${ORACLE_HOME}/bin:${PATH}"

# 重定向标准输出、错误输出到日志文件,完整打印所有日志
exec > "${LOG_FILE}" 2>&1

echo "======================================================"
echo "            Oracle RMAN 全量备份任务启动"
echo "执行时间: $(date '+%Y-%m-%d %H:%M:%S')"
echo "备份总目录: ${BACKUP_DIR}"
echo "待备份实例: ${ORACLE_SID_LIST}"
echo "ORACLE_HOME: ${ORACLE_HOME}"
echo "======================================================"
echo ""

# 循环遍历每个实例执行备份
for sid in ${ORACLE_SID_LIST}
do
    echo "=================================================="
    echo "  开始备份实例: ${sid}  |  时间: $(date '+%Y-%m-%d %H:%M:%S')"
    echo "=================================================="
    export ORACLE_SID="${sid}"

    # RMAN 执行,完整输出所有日志
    rman target / <<EOF
sql 'alter system checkpoint';
# 0级压缩全库备份
backup as compressed backupset incremental level 0 database format '${BACKUP_DIR}/${sid}_full_%d_%T_%U';

# 切换当前联机日志,保证归档完整性
sql 'alter system archive log current';

# 归档日志备份,成功后自动删除原归档
backup as compressed backupset archivelog all format '${BACKUP_DIR}/${sid}_arch_%d_%T_%U' delete all input;

# 交叉校验+清理失效归档元数据
crosscheck archivelog all;
delete noprompt expired archivelog all;

# 按 RETENTION POLICY 清理过期备份
report obsolete;
delete noprompt obsolete;
exit;
EOF

    # 判断单实例备份执行结果
    if [ $? -eq 0 ];then
        echo "【完成】实例 ${sid} 备份执行正常"
    else
        echo "【异常】实例 ${sid} 备份执行失败,请检查日志!"
    fi
    echo ""
done

echo "======================================================"
echo "所有实例备份任务执行完毕"
echo "结束时间: $(date '+%Y-%m-%d %H:%M:%S')"
echo "完整日志文件: ${LOG_FILE}"
echo "======================================================"
相关推荐
计算机安禾4 小时前
【数据库系统原理】第19篇:计算机存储层次结构与数据库文件的物理组织
数据库·oracle
JAVA面经实录9174 小时前
操作系统面试题
java·服务器·数据库·计算机网络·面试
摇滚侠5 小时前
mariadb-libs 被 mysql-community-libs-5.7.28-1.el7.x86_64 取代
数据库·mysql·mariadb
DIY源码阁5 小时前
JavaSwing饮品管理系统 - MySQL版
java·数据库·mysql·eclipse
专注搞钱5 小时前
GPT-4o写设备Recipe:从3小时到10分钟
数据库·人工智能·gpt·半导体
东风破1376 小时前
达梦数据库实战:备份恢复与数据迁移全攻略(实例初始化、服务注册、路径迁移)
数据库·chrome
SelectDB技术团队7 小时前
2026 SelectDB AI 产品发布会:Agent Native 数据基础设施能力全景发布
数据库·人工智能·agent·apache doris·selectdb
爱吃羊的老虎7 小时前
【数据库】模块一:数据库基础与关系代数
数据库
dishugj7 小时前
iSCSI + Multipath + ASM:Oracle RAC 共享存储技术链详解
数据库·oracle
yoothey8 小时前
MySQL事务机制解析 - 面试高分知识点
数据库·mysql·面试