阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Oracle 10g闪回数据库 (Flashback Database)

202次阅读
没有评论

共计 3581 个字符,预计需要花费 9 分钟才能阅读完成。

生产上要做灾备系统的应急切换演练,灾备端是由 OGG 搭建的。由于生产库都比较大 10 多 T,不想演练后重新初始化灾备库,Oracle 生产库版本为 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 天)
查看闪回恢复区里已生成闪回日志
1234 [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

更多 Oracle 相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-01/139418.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计3581字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中