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 2025-07-06 初始版本 暮渔木鱼
相关推荐
白鲸开源1 小时前
(二)从分层架构到数据湖仓架构:数据仓库分层下的技术架构与举例
大数据·数据库·数据分析
好玩的Matlab(NCEPU)1 小时前
Redis vs RabbitMQ 对比总结
数据库·redis·rabbitmq
21号 11 小时前
16.MySQL 服务器配置与管理
服务器·数据库·mysql
我的offer在哪里1 小时前
MongoDB
数据库·mongodb
练习时长一年3 小时前
AI开发结构化输出
数据库
IvorySQL3 小时前
灾难恢复工具内核细节探究与分享
数据库·postgresql·开源
lypzcgf3 小时前
商城小程序数据库表结构文档
数据库·小程序·电商
jjw_zyfx3 小时前
Ubuntu上vue3 vite使用MBTiles搭建地图服务器
服务器·数据库·ubuntu
EndingCoder4 小时前
Node.js SQL数据库:MySQL/PostgreSQL集成
javascript·数据库·sql·mysql·postgresql·node.js
静听山水5 小时前
SQLite
数据库·sqlite