博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle10g 闪回数据库 (Flashback Database)
阅读量:5963 次
发布时间:2019-06-19

本文共 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,如需转载请自行联系原作者

你可能感兴趣的文章
MVC中的三个模块
查看>>
Line: 220 - com/opensymphony/xwork2/spring/SpringObjectFactory.java:220:-1
查看>>
oracle 常用命令大汇总
查看>>
2012年春运火车票电话和网上订票技巧、攻略
查看>>
运维工程师的职责和前景
查看>>
Gcc编译流程解析
查看>>
根据request获取请求路径
查看>>
mysql 并行复制
查看>>
傲不可长,欲不可纵,乐不可极,志不可满——提高个人修养
查看>>
linux系统增加swap容量的方法
查看>>
远程推送
查看>>
后台调用gps
查看>>
HTML5标签的语义认知和理解(1)
查看>>
MySQL日志功能详解(2)
查看>>
HP LaserJet 305X 和 339X 系列一体机如何设置手动或自动接收传真?
查看>>
linux之权限之隐藏权限
查看>>
设计模式学习网址和书籍
查看>>
[李景山php]每天TP5-20170115|thinkphp5-Model.php-8
查看>>
前端seo注意事项!
查看>>
ConcurrentHashMap 线程安全
查看>>