Oracle10g 闪回数据库 (Flashback Database)

生产上要做灾备系统的应急切换演练,灾备端是由OGG搭建的。由于生产库都比较大10多T,不想演练后重新初始化灾备库,生产库版本为10.2.0.4,于是想到10g的新特性flashback database。演练开始前记录一个还原点,演练结束后闪回到这个还原点,重新同步ogg即可。

测试闪加数据库。

一、开启FLASHBACK DATABASE

数据库版本:10.2.0.4

启用FLASHBACK DATABASE数据库必须为ARCHIVELOG模式,还需要有一个闪回恢复区用于存储闪回日志,RAC中闪回恢复区必须在集群文件系统或ASM中。

--数据库已开启归档,但还未启用FLASHBACK
SQL> select flashback_on,log_mode from v$database;

FLASHBACK_ON					       LOG_MODE
------------------------------------------------------ ------------------------------------
NO						       ARCHIVELOG
--调整参数
SQL> alter system set db_recovery_file_dest_size=3G scope=spfile;

System altered.

SQL> alter system set db_recovery_file_dest=‘/u01/app/oracle/flashback_area/‘ scope=spfile;

System altered.

SQL> alter system set db_flashback_retention_target=2880 scope=spfile; 

System altered.
--关闭数据库
SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
--启动到mount状态,开启FLASHBACK
SQL> startup mount;
ORACLE instance started.

Total System Global Area  599785472 bytes
Fixed Size		    2085776 bytes
Variable Size		  192941168 bytes
Database Buffers	  398458880 bytes
Redo Buffers		    6299648 bytes
Database mounted.
SQL> alter database flashback on;

Database altered.
--启动数据库
SQL> alter database open;

Database altered.
--查看新状态
SQL> select flashback_on,log_mode from v$database;

FLASHBACK_ON					       LOG_MODE
------------------------------------------------------ ------------------------------------
YES						       ARCHIVELOG

官方文档:http://docs.oracle.com/cd/B19306_01/backup.102/b14192/rpfbdb003.htm#sthref509

db_recovery_file_dest_size参数表示闪回恢复区的大小

db_recovery_file_dest参数表示闪回恢复区目录

db_flashback_retention_target表是闪回日志保留的时间,单位为分,默认1440(1天)

查看闪回恢复区里已生成闪回日志

[[email protected] flashback_area]$ cd /u01/app/oracle/flashback_area/MYDB/flashback/
[[email protected] flashback]$ ls -l
total 8020
-rw-r----- 1 oracle oinstall 8200192 Jan  9 14:48 o1_mf_d76cxc1r_.flb

二、创建测试表

SQL> conn zx/zx
Connected.
SQL> create table flash_t as select * from all_tables;

Table created.

SQL> insert into flash_t select * from flash_t;

1559 rows created.

SQL> /

3118 rows created.

SQL> commit; 

Commit complete.

SQL> select count(*) from flash_t;

  COUNT(*)
----------
      6236

三、查看数据库可以闪回的时间点

SQL> select * from V$FLASHBACK_DATABASE_LOG;

OLDEST_FLASHBACK_SCN OLDEST_FLASHBACK_ RETENTION_TARGET FLASHBACK_SIZE ESTIMATED_FLASHBACK_SIZE
-------------------- ----------------- ---------------- -------------- ------------------------
	     7762668 20170109 14:37:32		   2880       14467072		      590954496

四、测试闪回数据库到一个时间点

--记录当前SCN用于闪回数据库
SQL> SELECT CURRENT_SCN FROM V$DATABASE;

CURRENT_SCN
-----------
    7765990
--删除测试表
SQL> conn / as sysdba
Connected.
SQL> select count(*) from zx.flash_t;

  COUNT(*)
----------
      6236

SQL> drop table zx.flash_t;

Table dropped.

SQL> select count(*) from zx.flash_t;
select count(*) from zx.flash_t
                        *
ERROR at line 1:
ORA-00942: table or view does not exist
--闪回数据库
SQL> shutdown immediate;
Database closed.
Database dismounted.
ORACLE instance shut down.
SQL> startup mount;
ORACLE instance started.

Total System Global Area  599785472 bytes
Fixed Size		    2085776 bytes
Variable Size		  192941168 bytes
Database Buffers	  398458880 bytes
Redo Buffers		    6299648 bytes
Database mounted.
--执行闪回
SQL> flashback database to scn 7765990;

Flashback complete.
--以resetlogs方式打开数据库
SQL> alter database open resetlogs;
--可以使用alter database open read only打开数据库查看闪回后数据库的状态,如果闪回的不理想,重启到mount模式重新做flashback database
Database altered.
--验证测试表得到恢复
SQL> select count(*) from zx.flash_t;

  COUNT(*)
----------
      6236

闪回还可以指定时间或还原点

FLASHBACK DATABASE TO RESTORE POINT BEFORE_CHANGES;

FLASHBACK DATABASE TO TIME "TO_DATE(‘09/20/00‘,‘MM/DD/YY‘)";

官方文档:http://docs.oracle.com/cd/B19306_01/backup.102/b14192/flashptr005.htm#BGBDCAFA

时间: 2024-10-03 09:02:53

Oracle10g 闪回数据库 (Flashback Database)的相关文章

Oracle 闪回特性(FLASHBACK DATABASE)

--===================================== -- Oracle 闪回特性(FLASHBACK DATABASE) --===================================== 闪回技术通常用于快速简单恢复数据库中出现的认为误操作等逻辑错误,从闪回的方式可以分为基于数据库级别闪回.表级别闪回.事务 级别闪回,根据闪回对数据的影响程度又可以分为闪回恢复,闪回查询.闪回恢复将修改数据,闪回点之后的数据将全部丢失.而闪回查询则可 以查询数据被DML的

闪回数据库的使用

oracle闪回技术-----使用闪回日志来恢复用户的逻辑错误,这种修复只针对用户逻辑错误的恢复,而不涉及整个数据库的恢复 恢复更具有针对性而且恢复时间大大减少. 对于闪回数据库而言,闪回日志不会被归档 启用闪回数据库-----数据库处于归档模式 使用DB_RECOVERY_FILE_DEST参数指定的目录作为存储目录,该参数的值即为快速恢复区 db_flashback_retention_target,该参数的值是一个一分钟为单位的数字. 通过数据字典v$flashback_database_

Flashback Database 闪回数据库

一.  Flashback Database 说明 Flashback Database 功能非常类似与 RMAN 的不完全恢复, 它可以把整个数据库回退到过去的某个时点的状态, 这个功能依赖于 Flashback log 日志. 比RMAN 更快速和高效. 因此 Flashback Database 可以看作是不完全恢复的替代技术. 但它也有某些限制:(1)Flashback Database 不能解决 Media Failure, 这种错误 RMAN 恢复仍是唯一选择.(2)如果删除了数据文

Oracle Flashback Technologies - 闪回数据库

根据指定的SCN,使用rman闪回数据库 #查看可以闪回到多久前 SQL> select * from v$flashback_database_log; #查看当前的SCN SQL> select current_scn from v$database; CURRENT_SCN ----------- 1462273 SQL> #关闭数据库 $ rman target / Recovery Manager: Release 11.2.0.4.0 - Production on Tue

【DG】利用闪回数据库(flashback)修复Failover后的DG环境

利用闪回数据库(flashback)修复Failover后的DG环境 1.1  BLOG文档结构图 1.2  前言部分 1.2.1  导读和注意事项 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知道的知识,~O(∩_∩)O~: ① Failover后DG环境的恢复方法(重点) ② DG的基本维护操作 ③ GC客户端软件的安装 ④ 利用GC快速搭建一套DG环境 ⑤ Failover和Switchover的区别 ⑥ 其它维护操作 1.3  本文简介 10月23和24日考

11G 闪回数据库

第一种场景 库是用来培训或测试环境的,测试完毕后恢复原来的样子 [email protected] odb>archive log list; Databaselog mode            No Archive Mode Automaticarchival             Disabled Archivedestination           USE_DB_RECOVERY_FILE_DEST Oldestonline log sequence      220 Curre

[转]Oracle DB执行闪回数据库

? 配置闪回数据库 ? 执行闪回数据库操作 ? 监视闪回数据库 闪回数据库 闪回数据库操作: ? 作用类似于数据库的倒带按钮 ? 可以在用户造成了逻辑数据损坏的情况下使用 闪回数据库 使用闪回数据库,通过还原自先前某个时间点以来发生的所有更改,可快速将数据库恢复到那个时间的状态.因为不需要还原备份,所以此操作速度很快.可以使用此功能还原导致逻辑数据损坏的更改. 使用闪回数据库时,Oracle DB 可使用过去的块映像回退对数据库的更改.在正常数据库操作期间,Oracle DB 会不定期地将这些块

实验-闪回数据库

一.打开闪回数据库 1.确保数据库处于归档模式,如果为非归档模式,将数据库转换成归档模式 SQL> select name,log_mode from v$database; NAME LOG_MODE --------- ------------ ORCL NOARCHIVELOG SQL> select flashback_on from v$database; FLASHBACK_ON ------- NO 设置为归档模 Connected to Oracle Database 10g

flashbackup闪回数据库

某时间删除了一个表 SQL> delete test1; 50000 rows deleted. 1.关闭数据库,启动到mount状态(abort数据库能快速关闭,但是可能会丢数据) SQL> shutdown abort; ORACLE instance shut down. SQL> startup mount; 2.基于时间戳闪回数据库(20:55) SQL> flashback database to timestamp to_timestamp('2015-09-22 2