oracle控制文件的备份和恢复以及丢失后的各种情况
一、控制文件备份的方法:
可以热备,rman备,冷备(不过我们一般不使用冷备)
热备:
alter database backup controlfile to '<dir>'; 热备控制文件
alter database backuo controlfile to trace as '<dir>' 得到建立控制文件的脚本
rman备:
rman> backup current controlfile;
rman> backup database include current controlfile;
或
设置控制文件的自动备份
rman> configure controlfile autobackup on;
二、控制文件恢复步骤:
1.对于非归档数据库:
1.)先做好全备,然后建立新的控制文件即可。
2.对于归档数据库:(建议也先全备,预防自己不能恢复时可以求助高手)
1.)从备份中还原;
2.)用重做日志恢复。
三、控制文件丢失分类
1.有备份:
1.)在线镜像备份:当前控制文件,即control_files初始化参数所指向的除去损坏的
控制文件以外的控制文件;
2.)结构备份:控制文件备份后,数据库的结构没发生变化(例如添加删除表空间,重做日志文件);
3.) 历史备份:控制文件备份后,数据库的结构发生了变化或日志丢失等
2.无备份也无trace跟踪文件
四、有备份的恢复
发现控制文件损坏后
1.SQL>shutdown abort
2.SQL>startup
提示错误ora-00205控制文件出错或ora-00227控制文件存在坏块,数据库启动到started状态
3.首先查看是否存在在线镜像备份,若存在,则按以下步骤恢复:
1.) 查看警告日志,确定哪些控制文件损坏了;
2.) 将正确的控制文件复制到损坏了的控制文件的位置上;
3.) SQL> alter database mount;
4.) SQL> alter database open;
否则,看是否存在结构备份,若存在,按以下步骤恢复:
1)进入rman:rman target/
2)从备份中还原控制文件
RMAN>restore controlfile from autobackup;(自动备份)
或
RMAN>restore controlfile from '手动备份的控制文件的位置';(手动备份)
3)设置数据库到mount状态
RMAN>alter database mount;
4)介质恢复
RMAN>recover database;
5)RMAN>alter database open resetlogs;
如果只有历史备份:
使用历史备份后出现不一致,以下2种情况需要手动修复不一致:
1.)备份控制文件中具有某个数据文件或变空间的信息,但实际不存在
2.)备份中没有某个在线日志组的信息,但实际是存在的(在恢复时用recover database using backup
controlfile 在提示中输入;
A、对于自动修复不一致的情况,其恢复步骤与结构备份的手动备份相同
B、备份控制文件中具有某个数据文件或表空间的信息,但实际不存在
1)进入rman:rman target/
2)从备份中还原控制文件
RMAN>restore controlfile from '手动备份的控制文件的位置';(手动备份)
3)设置数据库到mount状态
RMAN>alter database mount;
4)此时不能直接回复数据库,而应使恢复操作不理睬这个丢失的数据文件或表空间
数据文件:
SQL>alter database datafile 文件号 offline;(数据文件)
恢复数据库
SQL>recover database using backup controlfile;
表空间(包括表空间内所有数据文件):
SQL>recover database skip tablespace 表空间名;
5)RMAN>alter database open resetlogs;
五、无备份恢复---建立新的控制文件
1.利用trace文件脚本或手动创建
2.SQL>shutdown abort
3.SQL>startup
提示错误ora-00205控制文件出错或ora-00227控制文件存在坏块,数据库启动到started状态
4.建立控制文件:
SQL>create controlfile reuse(/set) database "数据库名" noresetlogs(/resetlogs仅当
online logs损坏的情况下才使用)noarchivelog/archivelog
MAXLOGFILES 16
MAXLOGMEMBERS 3
MAXDATAFILES 100
MAXINSTANCES 8
MAXLOGHISTORY 4672
LOGFILE
GROUP 1 '重做日志路径' SIZE 50M,
.......
DATAFILE
'数据文件路径',
.......(不包括temp文件)
CHARACTER SET '字符集(AL32UTF8)'
;
5.介质恢复
sql> recover database
sql> alter database open;
sql> alter tablespace temp add tempfile 'temp数据文件位置'
最后恢复完成后记得备份控制文件
一、控制文件备份的方法:
可以热备,rman备,冷备(不过我们一般不使用冷备)
热备:
alter database backup controlfile to '<dir>'; 热备控制文件
alter database backuo controlfile to trace as '<dir>' 得到建立控制文件的脚本
rman备:
rman> backup current controlfile;
rman> backup database include current controlfile;
或
设置控制文件的自动备份
rman> configure controlfile autobackup on;
二、控制文件恢复步骤:
1.对于非归档数据库:
1.)先做好全备,然后建立新的控制文件即可。
2.对于归档数据库:(建议也先全备,预防自己不能恢复时可以求助高手)
1.)从备份中还原;
2.)用重做日志恢复。
三、控制文件丢失分类
1.有备份:
1.)在线镜像备份:当前控制文件,即control_files初始化参数所指向的除去损坏的
控制文件以外的控制文件;
2.)结构备份:控制文件备份后,数据库的结构没发生变化(例如添加删除表空间,重做日志文件);
3.) 历史备份:控制文件备份后,数据库的结构发生了变化或日志丢失等
2.无备份也无trace跟踪文件
四、有备份的恢复
发现控制文件损坏后
1.SQL>shutdown abort
2.SQL>startup
提示错误ora-00205控制文件出错或ora-00227控制文件存在坏块,数据库启动到started状态
3.首先查看是否存在在线镜像备份,若存在,则按以下步骤恢复:
1.) 查看警告日志,确定哪些控制文件损坏了;
2.) 将正确的控制文件复制到损坏了的控制文件的位置上;
3.) SQL> alter database mount;
4.) SQL> alter database open;
否则,看是否存在结构备份,若存在,按以下步骤恢复:
1)进入rman:rman target/
2)从备份中还原控制文件
RMAN>restore controlfile from autobackup;(自动备份)
或
RMAN>restore controlfile from '手动备份的控制文件的位置';(手动备份)
3)设置数据库到mount状态
RMAN>alter database mount;
4)介质恢复
RMAN>recover database;
5)RMAN>alter database open resetlogs;
如果只有历史备份:
使用历史备份后出现不一致,以下2种情况需要手动修复不一致:
1.)备份控制文件中具有某个数据文件或变空间的信息,但实际不存在
2.)备份中没有某个在线日志组的信息,但实际是存在的(在恢复时用recover database using backup
controlfile 在提示中输入;
A、对于自动修复不一致的情况,其恢复步骤与结构备份的手动备份相同
B、备份控制文件中具有某个数据文件或表空间的信息,但实际不存在
1)进入rman:rman target/
2)从备份中还原控制文件
RMAN>restore controlfile from '手动备份的控制文件的位置';(手动备份)
3)设置数据库到mount状态
RMAN>alter database mount;
4)此时不能直接回复数据库,而应使恢复操作不理睬这个丢失的数据文件或表空间
数据文件:
SQL>alter database datafile 文件号 offline;(数据文件)
恢复数据库
SQL>recover database using backup controlfile;
表空间(包括表空间内所有数据文件):
SQL>recover database skip tablespace 表空间名;
5)RMAN>alter database open resetlogs;
五、无备份恢复---建立新的控制文件
1.利用trace文件脚本或手动创建
2.SQL>shutdown abort
3.SQL>startup
提示错误ora-00205控制文件出错或ora-00227控制文件存在坏块,数据库启动到started状态
4.建立控制文件:
SQL>create controlfile reuse(/set) database "数据库名" noresetlogs(/resetlogs仅当
online logs损坏的情况下才使用)noarchivelog/archivelog
MAXLOGFILES 16
MAXLOGMEMBERS 3
MAXDATAFILES 100
MAXINSTANCES 8
MAXLOGHISTORY 4672
LOGFILE
GROUP 1 '重做日志路径' SIZE 50M,
.......
DATAFILE
'数据文件路径',
.......(不包括temp文件)
CHARACTER SET '字符集(AL32UTF8)'
;
5.介质恢复
sql> recover database
sql> alter database open;
sql> alter tablespace temp add tempfile 'temp数据文件位置'
最后恢复完成后记得备份控制文件