Flasback数据库(闪回数据库)
数据库闪回原理:
一旦启用了闪回数据库,修改的块映像会不时从数据库缓冲区复制到闪回缓冲区。通过新的后台恢复写入器(Recovery Writer, RVWR)将此闪回缓冲区内容刷新到磁盘和闪回日志接着LGWR将日志缓冲区刷新到磁盘,然后DBWR写数据文件。
执行数据库闪回时,Oracle读取闪回日志以提取每个改变块的数据块版本,并将这些版本复制到文件。
具体实验步骤如下:
1. 配置闪回数据库
//确保数据库处于archivelog模式
SQL> select log_mode from v$database;
LOG_MODE
------------
ARCHIVELOG
//创建闪回恢复区,并限定它占用的最大空间
SQL> alter system set db_recovery_file_dest='C:\ora\flash_recovery_area';
SQL> alter system set db_recovery_file_dest_size=1G;
//设置闪回保留目标时间。闪回日志是以循环方式重用,更新的数据将覆盖旧的数据。此参数指示oracle在重写它之前保留的分钟数。
SQL> alter system set db_flashback_retention_target=1440;
//干净关闭并加载数据库
SQL> shutdown immediate;
SQL> startup mount;
//启用闪回日志
SQL> alter database flashback on;
2. 监视闪回数据库
//查询闪回能力并估计为满足目标时间闪回日志所需空间
SQL> select retention_target, flashback_size, oldest_flashback_time
2 from v$flashback_database_log;
RETENTION_TARGET FLASHBACK_SIZE OLDEST_FLASHBACK_TIME
---------------- -------------- ---------------------
1440 8192000 2014-03-26 22:40:54
//显示启用闪回数据库而付出的代价,单位是每小时i/o字节数
SQL> select end_time, flashback_data, db_data, redo_data
2 from v$flashback_database_stat;
END_TIME FLASHBACK_DATA DB_DATA REDO_DATA
----------- -------------- ---------- ----------
2014-03-26 5472256 3719168 2918400
//查看闪回缓冲区大小,此大小不受dba控制
SQL> select * from v$sgastat where name='flashback generation buff';
POOL NAME BYTES
------------ -------------------------- ----------
shared pool flashback generation buff 3981204
3. 使用flasback闪回数据库
场景:在2014-03-26 22:40:54,dba不小心删除了用户scott。dba发现这个错误后用flashback闪回数据库
SQL> drop user scott cascade;
恢复步骤:
//此时其它类型的关闭都无意义
SQL> shutdown abort;
SQL> startup mount;
//闪回数据库并以只读模式打开(sqlplus中可以精确到秒,em中只能精确到分)
SQL> flashback database to timestamp to_timestamp('2014-03-26 22:40:54','yyyy-mm-dd hh24:mi:ss');
SQL> alter database open read only;
//闪回完毕后可以查看到模式已经恢复回来了,因为其中的对象可以查询到了
SQL> select * from scott.dept;
DEPTNO DNAME LOC
---------- -------------- -------------
10 ACCOUNTING NEW YORK
20 RESEARCH DALLAS
30 SALES CHICAGO
40 OPERATIONS BOSTON已选择8行。
//确定已经找到满意的时间点后执行恢复操作
SQL> shutdown abort;
SQL> startup mount;
SQL> recover database until time '2014-03-26 22:40:54';
//执行最后一次数据库关闭,并使用resetlogs打开来创建数据库的一个新化身,此时数据库可以正常使用
SQL> shutdown abort;
SQL> startup mount;
SQL> alter database open resetlogs;
//测试发现之前误删除的用户又回来了
SQL> select * from scott.dept;
DEPTNO DNAME LOC
---------- -------------- -------------
10 ACCOUNTING NEW YORK
20 RESEARCH DALLAS
30 SALES CHICAGO
40 OPERATIONS BOSTON已选择8行。
实验完毕
Flasback数据库(闪回数据库)的更多相关文章
- [Flashback]开启数据库闪回数据库功能
Flashback是Oracle中一个重要的功能,想要使用闪回数据库功能,需要将数据库置于闪回数据库的状态. 1.检查数据库是否开启归档状态 SQL> archive log list; Dat ...
- Oracle Flashback Technologies - 闪回数据库
Oracle Flashback Technologies - 闪回数据库 根据指定的SCN,使用rman闪回数据库 #查看可以闪回到多久前 SQL> select * from v$flash ...
- OCP读书笔记(12) - 执行闪回数据库
闪回数据库使用的是闪回日志,闪回日志存在于闪回目录(也就是快速闪回区中)闪回日志:就是数据块修改之前的镜像,简称前像 1.查看闪回目录的位置:show parameter recovery 如果闪回目 ...
- oracle闪回技术总结之闪回数据库
[实施步骤] 步骤一.设置如下的初始化参数: Sql>小时:以分钟为单位 SQL> 点00分左右发现表被删除 切了几个归档 22:00:38SQL>:06:05 SQL> :0 ...
- 【DG】利用闪回数据库(flashback)修复Failover后的DG环境
利用闪回数据库(flashback)修复Failover后的DG环境 1.1 BLOG文档结构图 1.2 前言部分 1.2.1 导读和注意事项 各位技术爱好者,看完本文后,你可以掌握如下的技能, ...
- Oracle 12c 新特性之 PDB 级别闪回数据库
在Oracle Database 12.1中,闪回数据库操作仅限于 CDB ,Oracle Database 12.2支持 CDB 与 PDB 数据库的闪回. PDB 的还原点种类:1. normal ...
- Flashback Database 闪回数据库
一. Flashback Database 说明 Flashback Database 功能非常类似与 RMAN 的不完全恢复, 它可以把整个数据库回退到过去的某个时点的状态, 这个功能依赖于 Fl ...
- ORACLE数据库闪回日志写满
网站页面无法显示完整.检查web服务是正常的,所以可能是ORACLE数据库出了问题. 首先检查闪回日志写满 然后检查归档日志文件写满的缘故了.使用以下几个命令可以看出当前归档日志文件的使用情况: se ...
- oracle数据库flashback系列--闪回数据库在dataguard中的使用
很多人在学习flashback database这个oracle技术的时候,都会有一个疑问,就是如果我只有一个数据库作为生产库的话,是否有这样的业务需求导致我们要把数据库闪回到以前的时间点?以及这样做 ...
随机推荐
- SQL Server 格式化时间format
select format(sysdatetime(),'yyyy-MM-dd HH:mm:ss'); SQL Server 2012才开始有这功能 这种样式很像oracle的to_char(sysd ...
- linux别名
alias: alias cdn ='cd /opt/lammp' [root@besttest /]# cdn[root@besttest lampp]# 如果想永久生效写进root/.bash ...
- [改善Java代码]正确使用String,StringBuffer,StringBuilder
CharSequence接口有三个实现类与字符串有关:String,StringBuffer,StringBuffer.虽然它们都与字符串有关,但是其处理机制是不同的. String类是不可改变的量, ...
- [改善Java代码]异步运算考虑使用Callable接口
多线程有两种实现方式: 一种是实现Runnable接口,另一种是继承Thread类,这两种方式都有缺点,run方法没有返回值,不能抛出异常(这两个缺点归根到底是Runable接口的缺陷,Thread也 ...
- Oracle查询被锁的表及进程的方法
Oracle查询可以有多种方法,下面为您介绍的是如何Oracle查询被锁的表及Oracle查询连接的进程的方法,希望对您能够有所帮助. 一.查看被锁的表 select p.spid,a.serial# ...
- hdu 3622 二分+2-SAT判定
思路:如题 #include<iostream> #include<algorithm> #include<cstring> #include<cstdio& ...
- 核心概念 —— 服务提供者
1.简介 服务提供者是Laravel应用启动的中心,你自己的应用以及所有Laravel的核心服务都是通过服务提供者启动. 但是,我们所谓的"启动"指的是什么?通常,这意味着注册事物 ...
- CSS3 伸缩布局盒模型记
CSS3 伸缩布局盒模型 CSS3引入的布局模式Flexbox布局,主要思想是让容器有能力让其子项目能够改变其宽度,高度,以最佳方式填充可用空间.Flex容器使用Flex项目可以自动放大与收缩,用来填 ...
- JMS - 消息确认
消息确认机制 消息确认协议是保证消息传送的关键所在,同时,支持确认也是 JMS API 语义的要求.以下将分别从消息生产者.消息服务器.消息消费者的角度,来考察消息确认机制. 从消息生产者的角度考察 ...
- .net System.Net.Mail 之用SmtpClient发送邮件 Demo
private static bool sendMail() { try { //接收人邮箱 string SendTo = "XXXXX@163.com"; //抄送人邮箱 st ...