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 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1775 天前
《从零搭建NestJS项目》
数据库·typescript
加号35 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏5 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐5 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再5 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
tryCbest5 天前
数据库SQL学习
数据库·sql