一 目的
定期将生产环境oracle数据库恢复到一台测试环境数据库服务器上,以验证备份是否有效,是否能正常恢复。
二 环境
这里以恢复orcl1库为例,计划在orcl这个实例上进行恢复测试。
三 实验步骤
3.1 在目标端创建和源端一样的备份目录
① 查看下源端备份脚本,确定备份目录。
这里是/backup/日期
示例:
202404080100
② 在目标端创建全备目录
su - oracle
mkdir -p /backup/202404080100
3.2 获取源端备份文件
如果备份文件上传到了ftp服务器上的话,则这样获取:
cd /backup/
vi downloadbak.sh
添加如下内容:
cd /backup/202404080100
ftp -ivn <<!
open ftp服务器ip
user 账号/密码
bin
cd 备份路径
mget *
bye
!
#开始下载备份
nohup sh downloadbak.sh > downloadbak.log 2>&1 &
tail -f downloadbak.log
检查日志和备份文件数量,大小,确保都下载成功了。
下载完毕后,最后一行会输出如下:
221 Goodbye. You uploaded 0 bytes and downloaded 20345794.00 KB.
3.3 确保目标端db_name和源端保持一致
如果不一致,后面恢复完控制文件,将数据库启动到mount状态时会报错:
ORA-01103: 控制文件中的数据库名 ''ORCL1'' 不是 ''ORCL''。
修改示例:
示例:
create pfile='/home/oracle/temp.ora' from spfile;
vi /home/oracle/temp.ora
将