flashback database 功能非常类似与rman的不完全恢复, 它可以把整个数据库回退到过去的某个时点的状态, 这个功能依赖于flashback log 日志。 比rman更快速和高效。 因此flashback database 可以看作是不完全恢复的替代技术。 但它也有某些限制:
1. flashback database 不能解决media failure, 这种错误rman恢复仍是唯一选择
2. 如果删除了数据文件或者利用shrink技术缩小数据文件大小,这时不能用flashback database技术回退到改变之前的状态,这时候就必须先利用rman把删除之前或者缩小之前的文件备份restore 出来, 然后利用flashback database 执行剩下的flashback datbase。
3. 如果控制文件是从备份中恢复出来的,或者是重建的控制文件,也不能使用flashback database。
4. 使用flashback database锁能恢复到的最早的scn, 取决与flashback log中记录的最早scn。
具体操作步骤如下:
1、开启flashback database的准备条件
a)、参数开关
select flashback_on,force_logging from v$database;
flashback_on force_logging
------------ -------------
no no
打开方法如下:
shutdown immediate;
startup mount;
alter database archivelog;
alter database flashback on;
alter database open;
alter database force logging;
到此,闪回数据库的2个参数flashback_on和force_logging均打开;
b)、闪回文件存放位置db_recovery_file
show parameter db_recovery_file;
设置闪回区文件存放路径和大小:
alter system set db_recovery_file_dest='/dba/fb' scope=both; --默认的路径位置一般不改变
alter system set db_recovery_file_dest_size=6g scope=both;
c)、设置可闪回时长
alter system set db_flashback_retention_target =1440 scope=both;
该参数用来控制flashback log 数据保留的时间,或者说,你希望flashback database 能够恢复的最早的时间点。
默认值是1440,单位是minute,即24 小时,需要注意的是该参数虽然未直接指定flash recovery area大小,但却受其制约,
举个例子假如数据库每天有10%左右的数据变动的话,如果该初始化参数值设置为1440,则flash recovery area 的大小至少要是当前数据库实际容量的10%,
如果该初始化参数设置为2880,则flash recovery area 的大小就至少是数据库所占容量的20%。
到此,数据库闪回条件已经准备完毕。
2、闪回最早时间的查看,若闪回的时刻比oldest_flashback_time还早,会报日志不足的错误.
select t.oldest_flashback_scn, t.oldest_flashback_time from v$flashback_database_log t ;
3、闪回操作
shutdown immediate;
startup mount;
flashback database to timestamp to_timestamp('2013-11-23 11:41:16','yy-mm-dd hh24:mi:ss'); --此时刻不能早于前面查出来的闪回最早时间
4、 打开数据库:
在执行完flashback database 命令之后,oracle 提供了两种方式让你修复数据库:
1). 直接alter database open resetlogs 打开数据库,当然,指定scn 或者timestamp 时间点之后产生的数据统统丢失。--此种方法等于是把数据库改到历史时间点了,闪回时间点后的一切都会消失。
2). 先执行alter database open read only 命令以read-only 模式打开数据库,,然后立刻通过逻辑导出的方式将误操作涉及表的数据导出,
再执行recover database 命令以重新应用数据库产生的redo,将数据库修复到flashback database 操作前的状态,
操作如下:
alter database open read only;
pl/sql工具,右击对象名,导出丢失的数据;
shutdown immediate;
startup mount;
recover database;--用redo日志进行数据库恢复,取消了闪回对数据库的影响;
alter database open;
说明:
执行recover database时 ,oracle会以当前controlfile所纪录的scn为准,利用archive log和 redo log的redo entry, 把相关的datafile 的 block恢复到“当前controlfile所纪录的scn”。
相关阅读:
oracle 11g flashback data archive(闪回数据归档)
oracle flashback闪回机制
flashback table快速恢复误删除的数据
oracle 备份恢复:flashback闪回
[oracle]闪回flashback功能的使用