开发者社区> 技术小胖子> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

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中。

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

官方文档: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天)

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

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')";

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


     本文转自hbxztc 51CTO博客,原文链接:http://blog.51cto.com/hbxztc/1890433,如需转载请自行联系原作者







版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
数据库代码化(Database-as-Code)实战(二)
前言 在数据库代码化(Database-as-Code)实战一文中介绍了如何借助 Flyway 实现 migration based 的数据库迁移。但在实践过程中,发现了如下问题: 随着项目的发展,迁移脚本数量会越来越多,而全新部署时由于要执行所有的历史变更,部署时间会越来越长。
1063 0
数据库代码化(Database-as-Code)实战
最近在做专有云输出时遇到了一个棘手的问题,客户需要将我们两年前发布的版本升级到最新版。由于跨度较长,产品代码和数据库 schema 都发生了巨大变化。产品代码部分因为采用了版本管理策略,拥有明确的升级路径,但数据库部分由于未采用代码化方案,导致升级路径缺失,整个升级过程非常艰难。
2750 0
EnterpriseDB (PPAS) Oracle兼容性Virtual Private Database(VPD) 数据隔离以及当前缺陷
不带barrier的视图是不安全的,我在前面写过文章来讲这个,以及如何攻击这种视图。https://yq.aliyun.com/articles/14731PostgreSQL 为了增强视图的安全,增加了barrier的属性,来解决被攻击的问题。PostgreSQL 9.5 则提供了RLS来达到表.
2275 0
好书推荐—《精通Oracle Database 12c SQL&PL/SQL编程》
这是学习SQL和PL/SQL的一本好书,适合没有一点SQL基础的入门者。看过很多学习SQL与PL/SQL的书,要么是需要一定的基础,要么是大量的基础知识堆砌而没有形成系统。
1009 0
Oracle Active database duplication
001 理论基础 active database duplication :A duplicate database that is created over a network without restoring backups of the target database. This technique is an alternative to backup-based duplication. 意即:duplicate数据库不需要通过还原目标数据库的备份,而是直接通过网络而创建。
741 0
RHEL 6/CentOS 6上安装Oracle 11.2.0.3(Gird/Database)及以上缺少pdksh包的解决方法
在RHEL 6/CentOS 6上安装Oracle Grid 11.2.0.3/Oracle Database 11.2.0.3及以上时,出现elfutils-libelf-devel和pdksh包缺少的提示: 但是实际上这两个包是不需要的,可以忽略继续安装。
936 0
一步一步搭建oracle 11gR2 rac+dg之database安装(五)
一步一步在RHEL6.5+VMware Workstation 10上搭建 oracle 11gR2 rac + dg 之database安装 (五) 本章目录结构: 这一步主要可能安装...
920 0
oracle 透明网关(oracle database gateway)介绍
安装过程文档:http://download.csdn.net/detail/changyanmanman/7737563 在企业里,通常可能有多种数据源,并且他们是异构的。
1479 0
文章
问答
文章排行榜
最热
最新
相关电子书
更多
Red Hat Enterprise IT, Open Source, and the Cloud
立即下载
从IT支撑业务到IT引领业务
立即下载
Oracle 数据库笔记
立即下载