Oracle 11g R2 物理冷备

Oracle 11g R2 物理冷备操作文档

版本:1.0
最后更新日期:2025-07-06


1. 环境配置信息

项目 配置详情
操作系统 Red Hat Enterprise Linux 7.9 (x86_64)
Oracle 版本 11.2.0.4 (64-bit)
数据库名 (DB_NAME) orcl
实例名 (INSTANCE) orcl
数据文件路径 /u01/app/oracle/oradata/orcl
控制文件路径 /u01/app/oracle/oradata/orcl/*.ctl
在线重做日志路径 /u01/app/oracle/oradata/orcl/redo*.log
归档日志路径 /u01/app/oracle/archivelog
参数文件路径 $ORACLE_HOME/dbs/initorcl.ora
密码文件路径 $ORACLE_HOME/dbs/orapworcl
备份目标目录 /backup/oracle_cold_backup (需提前创建)
备份保留策略 保留最近3次完整备份

权限要求 :所有操作使用 oracle 用户执行,备份目录需赋予读写权限:

bash 复制代码
sudo mkdir -p /backup/oracle_cold_backup
sudo chown -R oracle:oinstall /backup/oracle_cold_backup
sudo chmod -R 775 /backup/oracle_cold_backup

2. 备份前准备

2.1 检查数据库状态
bash 复制代码
sqlplus / as sysdba <<EOF
SELECT status FROM v\$instance;
ARCHIVE LOG LIST;  -- 确认归档模式状态
EXIT;
EOF
  • 预期输出
    STATUS = OPEN(运行中)
    Database log mode = Archive Mode(归档模式)
2.2 记录关键文件路径
sql 复制代码
-- 查询控制文件
SELECT name FROM v\$controlfile;

-- 查询数据文件
SELECT name FROM v\$datafile;

-- 查询在线重做日志
SELECT member FROM v\$logfile;
2.3 停止数据库监听(可选但推荐)
bash 复制代码
lsnrctl stop

3. 关闭数据库

bash 复制代码
sqlplus / as sysdba <<EOF
SHUTDOWN IMMEDIATE;
EXIT;
EOF
  • 验证关闭状态

    bash 复制代码
    ps -ef | grep ora_ | grep -v grep  # 应无Oracle进程

4. 执行物理冷备

4.1 备份数据库核心文件
bash 复制代码
# 创建备份目录结构
mkdir -p /backup/oracle_cold_backup/{datafiles,controlfiles,redologs,archivelogs,config}

# 备份数据文件(关键步骤)
cp -rp /u01/app/oracle/oradata/orcl/*.dbf /backup/oracle_cold_backup/datafiles/

# 备份控制文件
cp -rp /u01/app/oracle/oradata/orcl/*.ctl /backup/oracle_cold_backup/controlfiles/

# 备份在线重做日志
cp -rp /u01/app/oracle/oradata/orcl/redo*.log /backup/oracle_cold_backup/redologs/

# 备份参数文件和密码文件
cp $ORACLE_HOME/dbs/initorcl.ora /backup/oracle_cold_backup/config/
cp $ORACLE_HOME/dbs/orapworcl /backup/oracle_cold_backup/config/

# 备份归档日志(如果存在)
cp -rp /u01/app/oracle/archivelog/* /backup/oracle_cold_backup/archivelogs/
4.2 生成备份校验文件
bash 复制代码
# 记录文件MD5校验值
find /backup/oracle_cold_backup -type f -exec md5sum {} \; > /backup/oracle_cold_backup/backup_checksum.txt

# 记录备份时间点
echo "Backup Time: $(date +"%Y-%m-%d %H:%M:%S")" > /backup/oracle_cold_backup/backup_metadata.txt

5. 启动数据库

bash 复制代码
sqlplus / as sysdba <<EOF
STARTUP;
EXIT;
EOF

# 重启监听
lsnrctl start

验证状态

sql 复制代码
SELECT status FROM v\$instance;  -- 应返回 "OPEN"

6. 备份后检查

6.1 验证备份完整性
bash 复制代码
# 检查文件数量
ls -lR /backup/oracle_cold_backup | grep -c "^-" > file_count.txt

# 对比源文件数量(示例)
find /u01/app/oracle/oradata/orcl -name "*.dbf" | wc -l
cat file_count.txt | grep "datafiles" -A 10  # 数量需匹配
6.2 校验MD5值(可选)
bash 复制代码
md5sum -c /backup/oracle_cold_backup/backup_checksum.txt | grep FAILED  # 应无输出

7. 备份恢复测试(在测试环境执行)

注意 :以下操作在测试服务器执行,禁止在生产环境操作!

bash 复制代码
# 停止测试库
sqlplus / as sysdba <<EOF
SHUTDOWN IMMEDIATE;
EXIT;
EOF

# 清空原数据文件(模拟灾难)
rm -rf /u01/app/oracle/oradata/orcl/*

# 从备份恢复文件
cp -rp /backup/oracle_cold_backup/datafiles/* /u01/app/oracle/oradata/orcl/
cp -rp /backup/oracle_cold_backup/controlfiles/* /u01/app/oracle/oradata/orcl/
cp -rp /backup/oracle_cold_backup/redologs/* /u01/app/oracle/oradata/orcl/
cp /backup/oracle_cold_backup/config/initorcl.ora $ORACLE_HOME/dbs/
cp /backup/oracle_cold_backup/config/orapworcl $ORACLE_HOME/dbs/

# 启动数据库
sqlplus / as sysdba <<EOF
STARTUP MOUNT;
ALTER DATABASE OPEN RESETLOGS;  -- 必须使用RESETLOGS方式打开
EXIT;
EOF

# 验证数据
sqlplus scott/tiger@orcl <<EOF
SELECT COUNT(*) FROM emp;  -- 检查关键表数据
EXIT;
EOF

8. 备份清理策略

bash 复制代码
# 保留最近3次备份(示例脚本)
find /backup/oracle_cold_backup -type d -name "backup_*" -mtime +21 -exec rm -rf {} \;

9. 关键注意事项

  1. 停机窗口:冷备需关闭数据库,提前申请停机时间(建议业务低峰期操作)。

  2. 空间监控:确保备份目录有足够空间(至少为数据文件总大小的1.5倍)。

  3. 恢复测试:每季度至少执行一次恢复演练。

  4. 备份加密 :敏感数据建议使用 tar + openssl 加密备份:

    bash 复制代码
    tar czf - /backup/oracle_cold_backup | openssl enc -aes-256-cbc -out backup_$(date +%Y%m%d).tar.gz.enc

文档修订记录

版本 日期 修改内容 修改人
1.0 2024-07-06 初始版本 krielwus
相关推荐
小丁爱养花1 小时前
Redis 内部编码/单线程模型/string
数据库·redis·缓存·1024程序员节
l1t2 小时前
利用DuckDB SQL求解集合数学题
数据库·sql·算法·集合·duckdb
筵陌2 小时前
MYSQL表的操作
数据库·mysql·1024程序员节
一 乐2 小时前
汽车销售|汽车推荐|基于SprinBoot+vue的新能源汽车个性化推荐系统(源码+数据库+文档)
java·数据库·vue.js·汽车·毕设·汽车个性化推荐
虾说羊2 小时前
最细Maven教程以及Maven私服搭建
java·数据库·maven
RestCloud2 小时前
Kingbase与ETL:如何实现金融级数据库的安全数据同步
数据库
ajassi20003 小时前
开源 Linux 服务器与中间件(八)数据库--MariaDB
服务器·数据库·开源
华仔啊4 小时前
这20条SQL优化方案,让你的数据库查询速度提升10倍
数据库·后端·mysql
赵庆明老师4 小时前
C# 结合Redis Cache 访问MySQL数据库
数据库·redis·c#
IvorySQL4 小时前
为IvorySQL增添PACKAGE语法帮助
数据库·postgresql