网站首页 > 技术文章 正文
概述
如果说flashback query用来恢复指定时间的记录,flashback table可用来恢复被删除或者指定时间的表,那么
flashback database直接提供一个数据库级别的恢复,可以直接将整个数据库恢复到指定时间,相比于钱两者,粒度更大。
flashback database可以不借助备份的情况下,将数据库向前恢复。oracle为了实现flashback database特性,另外引入一组新日志文件:flashback logs。其实flashback lohs与所有的日志文件功能一样,用来计记录日志的,只不过这个日志保存的信息有些特别,并不是记录你的操作,而是记录操作前要修改的数据,就是数据块的钱影像,这些信息被写入这个专用的存储区,就是flash recovery area,简称FRA。
Oracle11g闪回数据库特点:
1、使用闪回数据库不能解决媒介故障;
2、如果控制文件已被重建,不能使用闪回数据库;
3、不能完成删除表空间的恢复。
配置闪回数据库:
1、配置闪回恢复区;
2、数据库要求运行在归档模式下;
3、需要在Mount状态下使用alter database flashback on启动。
开启flashback database的必备条件:
1.数据库必须处于归档模式
2.数据库必须指定flash recovery area(db_recovery_file_dest指定路径和db_recovery_file_dest_size指定大小)
3.数据库必须启动特性flashback database
4.初始化参数:db_flashback_retention_target 后面的值是时间,单位分钟,默认是1440
5.启用force logging
闪回数据库使用
语法:
FLASHBACK [STANDBY] DATABASE <database> {TO [SCN | TIMESTAMP] <EXP> | TO BEFORE [SCN | TIMESTAMP] <EXP>}
举例:
使用FLASHBACK DATABASE 闪回数据库到SCN 55444 mount 模式下
SQL>flashback database to scn 55444;
用resetlogs选项打开数据库
SQL>alter database open resetlogs
闪回数据库局限性:
如下情形不能进行闪回数据库操作:
1)控制文件被恢复或重新创建
2)表空间被 drop 掉
3)数据文件被压缩
1.配置 Flash Recovery Area
要想使用 Flashback Database, 必须使用 Flash Recovery Area,因为 FlashbackDatabase Log 只能保存在这里。 要配置的 2 个参数如下,一个是大小,一个是位置。如果数据库是 RAC,flash recovery area 必须位于共享存储中。数据库必须处于 archivelog 模式。
1) 更改闪回区大小:
SQL>ALTER SYSTEM SET DB_RECOVERY_FILE_DEST_SIZE=20GSCOPE=BOTH;
2) 更改闪回区路径:
SQL>ALTER SYSTEM SET DB _RECOVERY_FILE_DEST=' /u01/app/oracle/flashback/orcl/' SCOPE=BOTH;
对于 Flash Recovery Area,Oracle 是这样建议的,flash recovery area 设置的越大,flashback database 的恢复能力就越强,因此建议 flash recovery area 能够放的下所有的数据文件,增量备份,以及所有尚未备份的归档文件,当然还有它自己产生的 flashback logs。
在数据库运行过程中,oracle 自动向该区域写入文件,当剩余空间不足 15%的时候,它就会在 alert 中增加警告,提示你空间不足。但此时不会影响数据库的正常运转,直到所有空间统统被用掉之后,oracle 首先尝试删除寻些过期的文件,冗余文件或备份过的文件,如果这些做完了,还是没有空闲空间的话,数据库就被 hang 住了。
2.启用数据库 Flashback 功能
1). 数据库启动到 mount 状态
SQL> startup mount;
2). 检查 Flashback 功能, 缺省时功能是关闭的。
SQL> select name, current _scn, flashback_on from v$database; NAME CURRENT_SCN FLASHBACK_ON -------- ----------- ------------------ DBA 945715 NO
3). 启动 Flashback 功能
SQL> alter database flashback on; 数据库已更改。
4). 设置初始化参数:DB_FLASHBACK_RETENTION_TARGET
SQL>alter system set db_flashback_retention_target=1440 scope=both;
ps:该参数用来控制 flashback log 数据保留的时间。
5). 启动数据库
SQL>alter database open;
3.和 Flashback Database 相关的视图
1. V$database
这个视图可以查看是否启用了 Flashback database 功能
SQL> select flashback _on from v$database;
2. V$flashback_database_log
Flashback Database 所能回退到的最早时间,取决与保留的 Flashback Database Log 的多少, 该视图就可以查看许多有用的信息。
Oldest_flashback_scn / Oldest_flashback_time : 这两列用来记录可以恢复到最早的时点
Flashback_size: 记录了当前使用的 Flash Recovery Area 空间的大小
Retention_target: 系统定义的策略
Estimated_flashback_size: 根据策略对需要的空间大小的估计值
SQL> select oldest _flashback_scn os, to_char(oldest_flashback_time,'yy-mm-dd hh2 4:mi:ss') ot, retention_target rt,flashback_size fs, estimated_flashback_size es from v$flashback_database_log;
3. V$flashback_database_stat
这个视图用来对 Flashback log 空间情况进行更细粒度的记录和估计。 这个视图以小时为单位记录单位时间内数据库的活动量,Flashback_Data 代表 Flashback log 产生数量,DB_Date 代表数据改变数量,Redo_Date 代表日志数量,通过这 3 个数量可以反映出数的活动特点,更准确的预计 Flash Recovery Area 的空间需求
SQL> alter session set nls _date_format='hh24:mi:ss'; SQL> select *from v$flashback_database_stat;
因为没开闪回,这里也就不做演示了,大家有空可以自己测试下。
后面会分享更多关于devops和DBA方面内容,感兴趣的朋友可以关注下!
猜你喜欢
- 2024-10-13 国庆节快乐--一文看懂Oracle数据库跨版本下rman备份恢复过程
- 2024-10-13 史上最全Oracle文件损坏处理办法(附实验步骤)
- 2024-10-13 数据库数据恢复-ORACLE数据库常见故障的数据恢复可能性分析
- 2024-10-13 Oracle数据库不同损坏级别的恢复详情
- 2024-10-13 不懂数据库高可用、备份与恢复,数据库优化?看这本就够了
- 2024-10-13 windows系统回收站和Oracle回收站--致力于恢复不小心删除的对象
- 2024-10-13 Oracle数据误操作全面恢复实战(r11笔记第78天)
- 2024-10-13 TRUNCATE恢复-bbed truncate如何恢复
- 2024-10-13 服务器数据恢复-服务器断电导致Oracle数据库报错的...
- 2024-10-13 一起来学习Oracle的备份恢复基础吧-1
你 发表评论:
欢迎- 06-24发现一款开源宝藏级工作流低代码快速开发平台
- 06-24程序员危险了,这是一个 无代码平台+AI+code做项目的案例
- 06-24一款全新的工作流,低代码快速开发平台
- 06-24如何用好AI,改造自己的设计工作流?
- 06-24濮阳网站开发(濮阳网站建设)
- 06-24AI 如何重塑前端开发,我们该如何适应
- 06-24应届生靠这个Java简历模板拿下了5个offer
- 06-24服务端性能测试实战3-性能测试脚本开发
- 566℃Oracle分析函数之Lag和Lead()使用
- 566℃几个Oracle空值处理函数 oracle处理null值的函数
- 550℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 545℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 543℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 536℃【数据统计分析】详解Oracle分组函数之CUBE
- 526℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 519℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端富文本编辑器 (47)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)