本文共 3916 字,大约阅读时间需要 13 分钟。
生产上要做灾备系统的应急切换演练,灾备端是由OGG搭建的。由于生产库都比较大10多T,不想演练后重新初始化灾备库,生产库版本为10.2.0.4,于是想到10g的新特性flashback database。演练开始前记录一个还原点,演练结束后闪回到这个还原点,重新同步ogg即可。
测试闪加数据库。
一、开启FLASHBACK DATABASE
数据库版本:10.2.0.4
启用FLASHBACK DATABASE数据库必须为ARCHIVELOG模式,还需要有一个闪回恢复区用于存储闪回日志,RAC中闪回恢复区必须在集群文件系统或ASM中。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 | --数据库已开启归档,但还未启用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 |
官方文档:
db_recovery_file_dest_size参数表示闪回恢复区的大小
db_recovery_file_dest参数表示闪回恢复区目录
db_flashback_retention_target表是闪回日志保留的时间,单位为分,默认1440(1天)
查看闪回恢复区里已生成闪回日志
1 2 3 4 | [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 |
二、创建测试表
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | 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 |
三、查看数据库可以闪回的时间点
1 2 3 4 5 | 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 |
四、测试闪回数据库到一个时间点
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 | --记录当前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')";官方文档:
本文转自hbxztc 51CTO博客,原文链接:http://blog.51cto.com/hbxztc/1890433,如需转载请自行联系原作者