RMAN 备份数据库到DISK,然后进行数据恢复

一、rman备份

1. 全备脚本

vi bakup_level0.sql

connect target /
run {
     allocate channel c1 type disk;
     allocate channel c2 type disk;
     allocate channel c3 type disk;
     backup
     incremental
     filesperset
     format "/backup/orcl/lev0_%d_%s_%I_%T_%t.bak" database;
     release channel c1;
     release channel c2;
     release channel c3;

     allocate channel c1 type disk;
     allocate channel c2 type disk;
     allocate channel c3 type disk;
     sql "alter system archive logcurrent";
     backup format '/backup/orcl/arch_%T_%t_%U' archivelog all delete all input;
     release channel c1;
     release channel c2;
     release channel c3;

     allocate channel c1 type disk;
     backup format "/backup/orcl/spfile_%d_%s_%I_%T_%t.bak" spfile;
     release channel c1;

     allocate channel c1 type disk;
     backup format "/backup/orcl/controlfile_%d_%s_%I_%T_%t.bak" (current controlfile);
     release channel c1;

}

-- 执行调用rman脚本(start.sh)

#!/bin/sh
# exec: sh start.sh
# reload oracle env
# reload profile
[ -f ${HOME}/.bash_profile ] && . ${HOME}/.bash_profile
export NLS_DATE_FORMAT='yyyy-mm-dd HH24:MI:SS'

" ]]; then
    SCRIPT_NAME=$
else
    echo "usage: $0 filename... "
fi

# Define the work path
APP_PATH=/home/oracle/scripts
LOGPATH=${APP_PATH}/logs
[[ -d "${APP_PATH}" ]] || mkdir -p ${APP_PATH}
[[ -d "${LOGPATH}" ]] || mkdir -p ${LOGPATH}
SCRIPT_FILE=${APP_PATH}/${SCRIPT_NAME}
LOGFILE=${LOGPATH}/bklevel0_$(date +%Y%m%d%H%M%S).log
# execute scripts
[[ -f "${SCRIPT_FILE}" ]] && ${ORACLE_HOME}/bin/rman cmdfile ${SCRIPT_FILE} msglog ${LOGFILE}

2. 增备(level 1)脚本

connect target /

run {
        allocate channel c1 type disk;
        allocate channel c2 type disk;
        allocate channel c3 type disk;
        # REM   cumulative
        backup
        incremental
        filesperset
        format "/backup/orcl/lev1_%d_%s_%I_%T_%t.bak" database;
        release channel c1;
        release channel c2;
        release channel c3;

        allocate channel c1 type disk;
        allocate channel c2 type disk;
        sql "alter system archive log current";
        backup format '/backup/orcl/arhc_%T_%t_%U' archivelog all delete all input;
        release channel c1;
        release channel c2;

        allocate channel c1 type disk;
        backup format "/backup/orcl/spfile_%d_%s_%I_%T_%t.bak" spfile;
        release channel c1;

        allocate channel c1 type disk;
        backup format "/backup/orcl/controlfile_%d_%s_%I_%T_%t.bak" (current controlfile);
        release channel c1;
    }

2.2 执行增备脚本

sh start.sh bakup_level1.sh

3. 备份归档日志

-- vi bakup_arch.sql
connect target /

run {
     allocate channel c1 type disk;
     allocate channel c2 type disk;
     sql "alter system archive log current";
     backup format '/backup/orcl/arhc_%T_%t_%U' archivelog all delete all input;
     release channel c1;
     release channel c2;

     allocate channel c1 type disk;
     backup format "/backup/orcl/spfile_%d_%s_%I_%T_%t.bak" spfile;
     release channel c1;

     allocate channel c1 type disk;
     backup format "/backup/orcl/controlfile_%d_%s_%I_%T_%t.bak" (current controlfile);
     release channel c1;
}

4. 维护rman备份集

connect target /
run{
    allocate channel for maintenance type disk;
    report obsolete;
    delete noprompt obsolete;
    release channel;
}

二、利用rman备份集恢复

1. 恢复步骤

1)安装oracle db软件,建议与源库版本一致;

2)目标端创建pfile,即相关目录(adump);

3)目标端创建密码文件

4)目标端启动nomount状态并创建spfile;

5)rman 恢复控制文件

6)还原数据文件

7)同步归档备份集到目标端并还原归档日志到目标端数据库

8)resetlog打开数据库

9)创建临时表空间

2. 具体操作代码

2.1)目标端创建pfile,即相关目录(adump)

# 创建pfile文件
vi pfile.ora

*.audit_file_dest='/oracle/app/oracle/admin/orcl/adump'
*.audit_sys_operations=TRUE
*.audit_trail='DB'
*.compatible='11.2.0.4.0'
*.control_files='/oradata1/orcl/control01.ctl'
*.db_block_size=
*.db_domain=''
*.db_files=
*.db_name='orcl'
*.diagnostic_dest='/oracle/app/oracle'
*.dispatchers=''
orcl.log_archive_dest_1='location=/arch1'
orcl.log_archive_format='orcl_%t_%s_%r.arc'
*.max_dump_file_size='1024M'
*.O7_DICTIONARY_ACCESSIBILITY=FALSE
*.open_cursors=
*.parallel_force_local=TRUE
*.parallel_max_servers=
*.parallel_threads_per_cpu=
*.pga_aggregate_target=
*.processes=
*.remote_login_passwordfile='EXCLUSIVE'
*.sga_target=
*.undo_tablespace='UNDOTBS1'

# 创建目录
export ORACLE_SID=orcl
mkdir -p /oracle/app/oracle/admin/${ORACLE_SID}/{adump,pfile,dpdump}

2.2)目标端创建密码文件

2.3)目标端启动nomount状态并创建spfile

sqlplus / as sysdba
startup nomount pfile='/home/oracle/pfile.ora';
create spfile from pfile='/home/oracle/pfile.ora';

--使用spfile启动数据库
sqlplus / as sysdba <<EOFshutdown immediate;startup nomount;quit;EOF

2.4)rman 恢复控制文件

rman target /
set dbid=<database id>;
run{  restore controlfile from '/backup/orcl/controlfile_orcl_292_1223534412_20170418_941608807.bak';  # 启动到mount  sql 'alter database mount';}

2.5)还原数据文件

connect target /
set dbid=<database id>;
 run{allocate channel c1 type disk;
allocate channel c2 type disk;
allocate channel c3 type disk;
 to '/oradata1/orcl/system01.dbf';
 to '/oradata1/orcl/sysaux01.dbf';
 to '/oradata1/orcl/undotbs01.dbf';
 to '/oradata1/orcl/users01.dbf';
 to '/oradata1/orcl/orcltbs01.dbf';
 to '/oradata1/orcl/orcltbs02.dbf';
 to '/oradata1/orcl/orcltbs03.dbf';
 to '/oradata1/orcl/orcltbs04.dbf';
 to '/oradata1/orcl/orcltbs05.dbf';
restore database;
switch datafile all;
recover database;
release channel c1;
release channel c2;
release channel c3;
}

2.6)同步归档备份集到目标端并还原归档日志到目标端数据库

rman target /
 set dbid=<database id>;
 run{
    allocate channel c1 type disk;
    allocate channel c2 type disk;
    set archivelog destination to '/backup/orcl/archivelog';
    ;
    release channel c1;
    release channel c2;
}

2.7)resetlog打开数据库

sqlplus "/ as sysdba" <<EOF# reset redo log

  alter database rename file '/oraredo1/redo01_1.log' to '/oradata1/orcl/redo01_1.rd';
  alter database rename file '/oraredo2/redo01_2.log' to '/oradata1/orcl/redo01_2.rd';
  alter database rename file '/oraredo1/redo02_1.log' to '/oradata1/orcl/redo02_1.rd';
  alter database rename file '/oraredo2/redo02_2.log' to '/oradata1/orcl/redo02_2.rd';

alter database open resetlogs;
quit;
EOF

2.8)创建临时表空间

select tablespace_name from dba_tablespaces where contents='TEMPORARY';

create temporary tablespace TEMP1 tempfile '/oradata1/orcl/temp01.dbf' size 10240M reuse;
alter database default temporary tablespace TEMP1;
drop tablespace TEMP including contents and datafiles;

RMAN 备份数据库到DISK后进行数据恢复的更多相关文章

  1. Oracle使用rman备份数据库时出现cannot reclaim的错误

    1. 按照<2 day DBA>中的guide,设置fast recovery area. SQL> ALTER SYSTEM SET DB_RECOVERY_FILE_DEST_S ...

  2. RMAN备份数据库与恢复数据库(整库)

    1 准备 2 1.1 检查数据库归档状态 2 1.2 RMAN登陆目标 2 2 备份全库 2 2.1 创建备份数据存储目录 2 2.2 RMAN备份全库 2 2.3 试验(备份后,改变数据) 5 2. ...

  3. 数据文件、日志文件、归档文件、控制文件、参数文件及RMAN备份数据库信息查询

    一.查看数据库信息:=====================1.数据文件 SQL> SELECT FILE#,STATUS,ENABLED,NAME FROM V$DATAFILE; FILE ...

  4. 使用RMAN备份数据库

    1.1使用控制文件备份全库 1.1.1配置备份路径 1.1.2 RMAN备份全库 1.2使用catalog数据库备份全库 1.2.1配置到远程数据库的TNS 1.2.2创建表空间及设置用户 1.2.3 ...

  5. RMAN备份数据库与表空间

    脚本: 数据库备份: backup database format='/u01/app/oracle/oradata/Backup/oradb_%d_%s.bak'; 表空间备份:backup tab ...

  6. RAC数据库的RMAN备份异机恢复到单节点数据库

    1.首先在rac环境用rman备份数据库.[oracle@rac1 admin]$ rman target /run{allocate channel c1 device type disk conn ...

  7. Oracle RMAN备份恢复指导书

    目 录 1 目的与范围... 1 2 术语和定义... 1 3 角色和职责... 2 4 使用RMAN备份数据库... 2 4.1.1 检查数据库模式... 2 4.1.2 连接到target数据库. ...

  8. 配置RMAN备份环境

    关于配置RMAN备份环境你可以给每个目标数据库设置一些固定的配置,这些配置控制着RMAN多个方面的行为.例如,你可配置备份的保存策略.默认的备份目录.默认的备份设备类型等.你可以用show命令来查看配 ...

  9. RMAN备份到NFS,报错 ORA-27054

    使用RMAN备份数据库到NFS挂载到的本地目录/backup 失败,失败提示如下: RMAN-03009: failure of backup command on ORA_DISK_1 channe ...

随机推荐

  1. net 异步与同步

    一.摘论 为什么不是摘要呢?其实这个是我个人的想法,其实很多人在谈论异步与同步的时候都忽略了,同步异步不是软件的原理,其本身是计算机的原理及概念,这里就不过多的阐述计算机原理了.在学习同步与异步之前, ...

  2. 了解java虚拟机---JVM的基本结构(1)

    1. JVM的基本结构 1.1. 类加载子系统 类加载子系统负责从文件或者网络中加载Class信息,加载的类信息存放于方法区的内存空间.方法区中可能还会存放运行时常量信息,包括字符串与数字常量.(这部 ...

  3. 还是畅通工程(hdu1233)并查集应用

    还是畅通工程 Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Sub ...

  4. 【C#数据结构系列】栈和队列

    一:栈 栈和队列也是线性结构,线性表.栈和队列这三种数据结构的数据元素以及数据元素间的逻辑关系完全相同,差别是线性表的操作不受限制,而栈和队列的操作受到限制.栈的操作只能在表的一端进行,队列的插入操作 ...

  5. Java开发中常用的设计模式(一)---工厂模式

    一. 准备工作 1. 本文参考自  自己理解的工厂模式,希望对大家有所帮助 二. 开始 以汽车工厂为例,首先有个汽车类的接口 Car,里面有个开车的方法 drive(),然后有个宝马车的类 BMW 和 ...

  6. 如何在idea中设置Tomcat虚拟路径

    设置项目的根路径: 设置指定文件的在Tomcat中的虚拟路径: 代码: String fileName = MyFileUtil.getFileName(uploadFileName); File f ...

  7. 封装7z软件实现批量文件或目录压缩

    哈哈,作为一个特别懒的运维人来说 兄弟我写了一个批量压缩文件或目录的小工具,用来批量压缩文件目录 弄一下,然后就不用管他了,后天看结果就好了 操作步骤: 1.选择想做压缩处理的根目录 2.选择你要的功 ...

  8. 第三十四天- 线程队列、线程池(map/submit/shutdown/回调函数)

    1.线程列队 queue队列 :使用import queue,用法与进程Queue一样 class queue.Queue(maxsize=0) # 先进先出: q = queue.Queue(3) ...

  9. @Transactional事务不起作用原因

    想必也有人遇到@Transactional事务不起作用,当时我遇到这个问题也很懵逼,明明别人的代码跟自己的一样,为什么别人的@Transactional事务起作用而自己的事务却没有起作用.如下举例子说 ...

  10. js常用正则收集

    1:非纯空白字符串且长度大于1:     /^\s*\S+[\s\S]*$/ 右侧可以正常匹配:“     11 1        1     a      ”  .“    1      aa” . ...