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 初始版本 暮渔木鱼
相关推荐
大气层煮月亮2 小时前
Oracle EBS ERP之报表开发—嵌入Web中的报表预览、报表打印
前端·数据库·oracle
会挠头但不秃2 小时前
Redis数据结构和常用命令
数据库·redis·缓存
楠目2 小时前
SQL注入与防御:从攻击原理到预编译防御
数据库·sql
无名前端小白2 小时前
Oracle 转 PostgreSQL, ora2pg docker compose 简单实践版
数据库·postgresql·oracle
庸人自扰614 小时前
Redis从零讲解
数据库·redis·缓存
lypzcgf5 小时前
Coze源码分析-资源库-删除数据库-后端源码-领域服务/数据访问层
数据库·go·coze·coze源码分析·智能体平台·ai应用平台·agent平台
cqsztech5 小时前
oracle linux 10 +pg18 源码安装要点
linux·数据库·oracle
健康平安的活着5 小时前
spring事务传播级别的实操案例2
数据库
安审若无5 小时前
Oracle 闪回过期后的解决方法
数据库·oracle