百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 优雅编程 > 正文

Oracle备份恢复之Flashback--Flashback Database

sinye56 2024-09-21 02:25 3 浏览 0 评论

概述

如果说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方面内容,感兴趣的朋友可以关注下!

相关推荐

Linux在线安装JDK1.8

首先在服务器pingwww.baidu.com查看是否可以连网然后就可以在线下载一、下载安装JDK1.81、在下载安装的同时做好一些准备工作...

Linux安装JDK,超详细

1、了解RPMRPM是Red-HatPackageManager(RPM软件包管理器)的缩写,这一文件格式名称虽然打上了RedHat的标志,但是其原始设计理念是开放式的,现在包括OpenLinux...

Linux安装jdk1.8(超级详细)

前言最近刚购买了一台阿里云的服务器准备要搭建一个网站,正好将网站的一个完整搭建过程分享给大家!#一、下载jdk1.8首先我们需要去下载linux版本的jdk1.8安装包,我们有两种方式去下载安装...

Linux系统安装JDK教程

下载jdk-8u151-linux-x64.tar.gz下载地址:https://www.oracle.com/technetwork/java/javase/downloads/index.ht...

干货|JDK下载安装与环境变量配置图文教程「超详细」

1.JDK介绍1.1什么是JDK?SUN公司提供了一套Java开发环境,简称JDK(JavaDevelopmentKit),它是整个Java的核心,其中包括Java编译器、Java运行工具、Jav...

Linux下安装jdk1.8

一、安装环境操作系统:CentOSLinuxrelease7.6.1810(Core)JDK版本:1.8二、安装步骤1.下载安装包...

Linux上安装JDK

以CentOS为例。检查是否已安装过jdk。yumlist--installed|grepjdk或者...

Linux系统的一些常用目录以及介绍

根目录(/):“/”目录也称为根目录,位于Linux文件系统目录结构的顶层。在很多系统中,“/”目录是系统中的唯一分区。如果还有其他分区,必须挂载到“/”目录下某个位置。整个目录结构呈树形结构,因此也...

Linux系统目录结构

一、系统目录结构几乎所有的计算机操作系统都是使用目录结构组织文件。具体来说就是在一个目录中存放子目录和文件,而在子目录中又会进一步存放子目录和文件,以此类推形成一个树状的文件结构,由于其结构很像一棵树...

Linux文件查找

在Linux下通常find不很常用的,因为速度慢(find是直接查找硬盘),通常我们都是先使用whereis或者是locate来检查,如果真的找不到了,才以find来搜寻。为什么...

嵌入式linux基本操作之查找文件

对于很多初学者来说都习惯用windows操作系统,对于这个系统来说查找一个文件简直不在话下。而学习嵌入式开发行业之后,发现所用到的是嵌入式Linux操作系统,本想着跟windows类似,结果在操作的时...

linux系统查看软件安装目录的方法

linux系统下怎么查看软件安装的目录?方法1:whereis软件名以查询nginx为例子...

Linux下如何对目录中的文件进行统计

统计目录中的文件数量...

Linux常见文件目录管理命令

touch用于创建空白文件touch文件名称mkdir用于创建空白目录还可以通过参数-p创建递归的目录...

Linux常用查找文件方法总结

一、前言Linux系统提供了多种查找文件的命令,而且每种查找命令都具有其独特的优势,下面详细总结一下常用的几个Linux查找命令。二、which命令查找类型:二进制文件;...

取消回复欢迎 发表评论: