设为首页 加入收藏

TOP

Oracle 10g闪回数据库 (Flashback Database)(一)
2017-01-20 08:15:12 】 浏览:433
Tags:Oracle 10g 数据库 Flashback Database

一、开启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模式重新做

首页 上一页 1 2 下一页 尾页 1/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇Oracle 11gR2 硬件导致重新添加节.. 下一篇Oracle虚拟索引

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目