13.3无备份恢复控制文件

没有备份恢复控制文件其实就是在nomount状态,create control创建一个新的控制文件。

dba必须知道4个信息才能正确的创建:数据库名在线日志路径及其大小在线的可读/写数据文件路径数据库字符集

其中指定数据库字符集是为了在打开数据库之前执行recover tablespace  ..或restore tablespace时可以正确解析表空间名称

--之前在dsi系列介绍了使用bbed查看数据文件头的方式来确定字符集,数据库名等方法。

--maxlogfiles 在线重做日志组数量上限的初始值,能够自动增长
--maxlogmembers日志组内在线日志数量上限的初始值,能够自动增长
--maxloghistory 记录最近产生的日志历史数量上限的初始值,能够自动增长
--maxdatafiles 数据文件数量上限的初始值,能够自动增长,但不能超过data_files的值。
--maxinstances 能够同时打开数据库的实例数,针对RAC环境必须确保该值大于或等于集群中的节点数

--在线日志无损情况下的重建

SQL>STARTUP NOMOUNT
CREATE CONTROLFILE REUSE DATABASE "ORCL" NORESETLOGS ARCHIVELOG
SQL> recover database;
SQL> alter database open;
SQL> select * from v$tempfile;
添加临时表空间
##添加临时表空间
SQL> ALTER TABLESPACE TEMP ADD TEMPFILE '/u01/app/oracle/oradata/orcl/temp01.dbf' SIZE 61865984 REUSE AUTOEXTEND ON NEXT 655360 MAXSIZE 32767M;
如果没有使用catalog,在重建控制文件后,原先保留在控制文件的备份、归档日志信息全部丢失
RMAN> list bakcup;
RMAN> catalog db_recovery_file_des; ##使用catalog命令将他们寻回
RMAN> report need backup;
SQL>CREATE CONTROLFILE REUSE DATABASE "ORCL" NORESETLOGS  ARCHIVELOG
MAXLOGFILES 16
MAXLOGMEMBERS 3
MAXDATAFILES 100
MAXINSTANCES 8
MAXLOGHISTORY 292
LOGFILE
GROUP 1 '/u01/app/oracle/oradata/orcl/redo01.log' SIZE 50M BLOCKSIZE 512,
GROUP 2 '/u01/app/oracle/oradata/orcl/redo02.log' SIZE 50M BLOCKSIZE 512,
GROUP 3 '/u01/app/oracle/oradata/orcl/redo03.log' SIZE 50M BLOCKSIZE 512
-- STANDBY LOGFILE
DATAFILE
'/u01/app/oracle/oradata/orcl/system01.dbf',
'/u01/app/oracle/oradata/orcl/sysaux01.dbf',
'/u01/app/oracle/oradata/orcl/undotbs01.dbf',
'/u01/app/oracle/oradata/orcl/users01.dbf',
'/u01/app/oracle/oradata/orcl/test01.dbf'
CHARACTER SET AL32UTF8
;

--在线日志损坏情况下的重建

控制文件损坏且没有备份,同时损坏的还有在线日志(current),分别采用重建控制文件和不完全恢复解决

SQL> STARTUP NOMOUNT

CREATE CONTROLFILE REUSE DATABASE "ORCL" RESETLOGS  ARCHIVELOG

因为控制文件是新建的,此时v$log\v$log_history不能提供任何与检查点进度有关的信息。

明知道是不完全恢复,但可以让rman首先尝试一次完全恢复,看看它能走多远,在没有使用catalog的情况下,使用catalog将备份和归档日志重新录入新的控制文件内

RMAN> catalog db_recovery_file_dest;
RMAN> run {
restore database;
recover database;
}
...
RMAN-06054:media recovery requesting unknown archived log for thead 1 with sequence 22 and starting SCN of 1082040
会看到到22号日志就无法进行了,不完全恢复可以登场了
RMAN> recover database until sequence 22;
RMAN> alter database open resetlogs;
最后添加临时表空间

--具有只读数据文件情况下的重建

“create database”命令datafile子句中不可以声明只读表空间的数据文件,它必须“缺席”,否则控制文件会将只读数据文件当成可读/写的在线数据文件处理

因为只读的数据文件没有任何更新,头部的SCN可能很低,低到库存的归档日志不够而无法恢复该文件,所以,在重建控制文件前,需要确认数据库有没有只读数据文件,如果有,必须特殊处理

--1 启动到nomount
--2 create controlfile创建新的控制文件,其中datafile子句不包含只读数据文件
--3 在mount执行recover database恢复数据库。若RMAN-06504错误继续执行SQLPLUS的recover database using backup controlfile命令,在Specify log提示符出现后输入正确的日志路径
--4 尝试用noresetlogs打开数据库,若不行用resetlogs打开
--5 修正只读数据文件的路径
--6执行alter tablespace ... online将只读表空间上线
--7 添加临时表空间
--SQL> create controlfile
--RMAN> catalog db_recovery_file_dest
--RMAN> recover database(rman-06054)
--SQL> select sequence# from v$archived_Log order by 1;
--SQL>v$Log,v$logfile
--SQL> recover database using backup controfile;
Specify log: {<RET>=suggested | filename | AUTO | CANCEL}
--SQL> alter database open resetlogs;
--SQL> alter tablespace test1 online;
--SQL> alter tablepsace temp add tempfile ‘’;

--使用控制文件快照恢复

实际上,控制文件还可能有一个“隐藏”的备份,那就是控制文件快照(control file snapshot),它相当于控制文件的镜像复制,默认路径

[oracle@DSI trace]$ cd $ORACLE_HOME/dbs

-rw-r----- 1 oracle oinstall 10043392 Jul 29 09:57 snapcf_orcl.f

只要曾经备份过控制文件或catalog发生过同步操作,快照就存在

使用快照恢复的一般步骤和使用控制文件镜像复制恢复是一致的

--1 将快照cp到控制文件的路径上
--2 启动到mount
--3 使用RMAN的recover database或者sqlplus的recover database using backup controlfile恢复数据库
--4 打开数据库

或者使用快照生成create controlfile命令

SQL> alter database backup controlfile to trace;

13.4 恢复数据文件

没有备份,数据文件可以在控制文件和数据字典的帮助下通过重做日志恢复,当然不是所有的数据文件都可以在没有备份的情况下恢复,若没有备份,普通数据文件可以在控制文件和数据字典的帮助下通过重做日志恢复。

无备份数据文件的恢复的主要步骤

--1 使用alter database create datafile创建新的空白数据文件
--2 使用recover datafile利用空白数据文件创建以来的所有重做日志恢复该文件

场景:test的数据文件test01.dbf丢失,数据库启动到mount状态报错,但是test自创建以来没有备份

SQL> startup
ORA-01157 : cannot identify/lock data file 6 - see DBWR trace file
ORA-01110: data file 6 ...
SQL> alter database datafile 6 offline;
SQL> alter database open;
SQL> alter database create datafile 6;
RMAN> recover datafile 6;
SQL> alter database datafile 6 online;

Oracle 无备份情况下的恢复--控制文件/数据文件的更多相关文章

  1. Oracle 无备份情况下的恢复--临时文件/在线重做日志/ORA-00205

    13.5 恢复临时文件 临时文件没有也不应该备份.通过V$TEMPFILE可以找到所有的临时文件. 此类文件的损坏会造成需要使用临时表空间的命令执行失败,不至于造成实例崩溃或session中断.由于临 ...

  2. Oracle 无备份情况下的恢复--密码文件/参数文件

    13.1 恢复密码文件 密码文件(linux 为例)在$ORACLE_HOME/dbs目录下,文件名的前缀是orapw,后接数据库实例名. [oracle@DSI backup]$ cd /u01/a ...

  3. Oracle备份恢复之无备份情况下恢复undo表空间

    UNDO表空间存储着DML操作数据块的前镜像数据,在数据回滚,一致性读,闪回操作,实例恢复的时候都可能用到UNDO表空间中的数据.如果在生产过程中丢失或破坏了UNDO表空间,可能导致某些事务无法回滚, ...

  4. 迁移/home目录至新硬盘分区总结--无备份情况下

    搞了一天,终于成功迁移.由于一开始就没备份过程实在很曲折. 希望本篇对那些没有备份习惯的朋友们有所帮助. 准备工作: sudo vim /etc/fstab 在文件中加入: /dev/sdb8     ...

  5. 在没有备份的情况下重新创建丢失的数据文件 (Doc ID 1149946.1)

    Recreating a missing datafile with no backups (Doc ID 1149946.1) APPLIES TO: Oracle Database - Enter ...

  6. oracle基于归档的增量异地恢复 --异地新增数据文件问题

    1 rac异地基于归档文件的增量恢复   2 遇到在主库新增数据文件 后 日志恢复出现路径问题 .   错误如下 : creating datafile fno=20 name=+DATA/dataf ...

  7. windows环境下,svn未备份情况下重新恢复

    公司有个同事在未打招呼的情况下把公司服务器进行重新装系统,崩溃啊.SVN之前未备份,还好SVN的库(Repositories)还在,如下图: 恢复办法如下: 由于之前安装的就是VisualSVN-Se ...

  8. PostgreSQL在没有备份情况下误删除Clog恢复

    创建实验表postgres# create table t (n_id int primary key,c_name varchar(300));CREATE TABLEpostgres# inser ...

  9. Oracle主库归档丢失,备库日志有gap,在不重建备库的情况下,恢复备库

    本文主要描述Oracle备库日志与主库日志之间有gap,切主库这部分gap的归档日志已经删除或丢失,如何在不重建备库的情况下,恢复备库. 欢迎转载,请注明作者.出处. 作者:张正 blog:http: ...

随机推荐

  1. C++ 程序设计语言

    好记性不如烂笔头. 第六章 标准库给出了静态断言,形式类似如下: stastic_assert(A,S);//当A不为true时,把S作为一条编译器错误信息输出 其最重要的用途是为泛型编程中作为形参的 ...

  2. thinkphp 多条件联合查询 where例句

    $where['username'] = array("eq",$username); $where['phone'] = array("eq",$userna ...

  3. uwsgi_response_write_body报错的几种情况

    1.uwsgi_response_write_body_do(): Broken pipe 出现这种情况一般是由于客户端无法等到服务端的回应而关闭了连接,常出现与nginx + uwsgi的情况,当u ...

  4. (转) linux实现ssh免密码登录的正确方法

    方法/步骤 验证ssh远程登录,未作免密处理的两台机器,登录时,是需要输入密码的 本地系统执行 ssh-keygen -t rsa 命令,生成密钥文件 在相应的目录下查看生成的密钥文件,其中:id_r ...

  5. hdu 1003 最大连续子串

    #include <bits/stdc++.h> #define PI acos(-1.0) #define mem(a,b) memset((a),b,sizeof(a)) #defin ...

  6. Python:JPG->JPEG

    由于要在网页上使用图片渐进加载,所以需要将其他图片格式转化为JPEG格式 考虑使用python来实现批量转换 需要先安装pillow: pip  install pillow 我这里将JPG格式转化为 ...

  7. 超级大佬已提前布局AI域名,人工智能时代真的来临了?

    近日,郭盛华公司巨资收购的ai域名引起了业界深度关注,ai人工智能行业想必大家都熟悉不会陌生,但是ai域名你知道吗?了解域名行业的米友,对于ai域名肯定都熟悉,为什么今天小编要突然提到ai域名?因为a ...

  8. rsync服务端排错思路

    rsync服务端排错思路       rsync服务端排错思路 查看rsync服务配置文件路径是否正确,正确的默认路径为/etc/rsyncd.conf 查看配置文件里host allow,host ...

  9. mysql数据库密码

    一. oOO6jpspg/j5 二. alter user root@localhost IDENTIFIED BY '123'; 三. create database s11Madking char ...

  10. 013:URL传参数

    URL传参数有两种方式: 1.采用在URL中使用变量的方式:在path的第一个参数中,使用'<参数名>'的方式可以传递参数,然后在对于的视图函数中也要写一个参数,并且视图函数中的参数名和U ...