Oracle10g 闪回数据库 (Flashback Database)
admin
2023-05-20 16:42:32
0

生产上要做灾备系统的应急切换演练,灾备端是由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天)

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

[oracle@rhel5 flashback_area]$ cd /u01/app/oracle/flashback_area/MYDB/flashback/
[oracle@rhel5 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



相关内容

热门资讯

坚定不移沿着习近平总书记指引的... 5月8日,淅川丹江小三峡碧水蜿蜒、青山环抱,峰峦叠翠、云雾轻笼,尽显生态之美。 张峰 摄●黄河干流(...
打响“河南服务”品牌丨一颗柠檬... 初夏时节,四川省安岳县通贤镇的柠檬果园里,枝叶繁茂、幼果缀枝。陆海燕正带着村民穿梭田间,为这一季的收...
离境退税2.0版政策上线 境外... 今天(18日),我国离境退税2.0版政策正式上线,以后境外旅客来华购物办理退税会更方便。首先是退税办...
习近平就推动哲学社会科学高质量... 习近平就推动哲学社会科学高质量发展作出重要指示强调加快构建中国哲学社会科学自主知识体系更好回答中国之...
河南多条高速采取管制措施 中央气象台5月18日6时继续发布暴雨黄色预警:预计,5月18日8时至19日8时,华南中西部沿海、西南...
全国零担物流30强 8豫企上榜 5月13日,物流进化发布最新年度零担行业榜单。在零担30强、全网快运10强、区域零担25强、大票零担...
坚定不移沿着习近平总书记指引的... “五一”假期,游客在只有河南·戏剧幻城观赏游玩。 河南日报全媒体记者 聂冬晗 摄●2025年,全省接...
微改革一线调研丨医教结合破解儿... “以前放学,他总是打不起精神,蔫蔫的。现在大不一样,前几天吃完晚饭,居然主动拉着我下楼散步。”5月9...
坚定不移沿着习近平总书记指引的... 田铺大塆美丽景色。 新县县委宣传部供图大别山层峦叠翠,古村落文脉悠长。5月12日清晨,新县田铺乡田铺...
千年古都的流量密码 ——“安阳... 【核心提示】2026河南省文化旅游发展大会将于5月22日至23日在安阳市召开。作为中国八大古都之一、...