oracle数据库异地恢复,ORACLE_数据库全备份+归档异地恢复

ORACLE_数据库全备份+归档异地恢复

发布时间:2020-08-04 19:39:36

来源:ITPUB博客

阅读:95

作者:adamjunior

全备份:

#!/bin/bash

export ORACLE_BASE=/u01/app/oracle

export ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1

export ORACLE_SID=ORCL

export PATH=$ORACLE_HOME/bin:$ORACLE_HOME/OPatch:$PATH

backtime=`date +"%y%m%d%H%M%S"`

$ORACLE_HOME/bin/rman target /   log=/home/oracle/full_backup_$backtime.log <

run{

allocate channel c1 device type disk;

allocate channel c2 device type disk;

allocate channel c3 device type disk;

allocate channel c4 device type disk;

sql 'alter system archive log current';

backup as compressed backupset full database format '/u01/app/oracle/back/full_%d_%T_%U';

sql 'alter system archive log current';

backup archivelog all format '/u01/app/oracle/back/arch_%d_%T_%s_%p.bak' delete input ;

backup current controlfile format '/u01/app/oracle/back/ctl_%d_%T_%s_%p.bak';

release channel c1;

release channel c2;

release channel c3;

release channel c4;

}

EOF

备份归档日志

RMAN > run {

backup archivelog all format '/u01/app/oracle/back/arch_%d_%T_%s_%p.bak' delete input ;

backup current controlfile format '/u01/app/oracle/back/ctl_%d_%T_%s_%p.bak';

}

备份参数文件

SQL> create pfile from spfile;

恢复至其他环境

1.修改参数文件路径

vi $ORACLE_HOME/dbs/initORCL.ora

2.启动数据库至nomount

SQL> startup pfile='/u01/app/oracle/product/11.2.0/dbhome_1/dbs/initORCL.ora';

3.恢复控制文件

$ cd /u01/app/oracle/backup

RMAN> restore controlfile from '/u01/app/oracle/backup/ctl_ORCL_20200311_19_1.bak';

RMAN> alter database mount;

3.恢复数据库

RMAN> run {

catalog start with '/u01/app/oracle/backup';

set newname for database to '/u01/app/oracle/oradata/DEMO/%U';

restore database;

switch datafile all;

switch tempfile all;

recover database;

}

Do you really want to catalog the above files (enter YES or NO)? yes

5. 修改日志文件

SQL> alter database rename file '/u01/app/oracle/oradata/ORCL/redo01.log' to '/u01/app/oracle/oradata/DEMO/redo01.log';

SQL> alter database rename file '/u01/app/oracle/oradata/ORCL/redo02.log' to '/u01/app/oracle/oradata/DEMO/redo02.log';

SQL> alter database rename file '/u01/app/oracle/oradata/ORCL/redo03.log' to '/u01/app/oracle/oradata/DEMO/redo03.log';

SQL>  ALTER DATABASE CLEAR LOGFILE GROUP 1;

SQL>  ALTER DATABASE CLEAR LOGFILE GROUP 2;

SQL>  ALTER DATABASE CLEAR LOGFILE GROUP 3;

6. 打开数据库

SQL> alter database open resetlogs;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值