【云原生进阶之数据库技术】第二章-Oracle-原理-4.6.3.3-闪回数据库技术

本文主要是介绍【云原生进阶之数据库技术】第二章-Oracle-原理-4.6.3.3-闪回数据库技术,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 闪回数据库

1.1 使用场景和限制

(1)一种快速的数据库恢复方案,这种恢复是基于用户的逻辑错误

比如:

  • 对表中的数据做了错误的操作
  • 插入了大量错误的数据
  • 删除了一个用户等

        此时通常是将数据库恢复到之前的某一个时间点。

        相比于原始的恢复方式需要先备份数据文件,再使用归档日志恢复到以前的时间点。

(2)闪回日志由oracle自动创建,并保存于闪回恢复区中,由闪回恢复区管理,因为是自动管理的,所以如果闪回恢复区空间不足,闪回日志也会自动删除。所以闪回恢复区应该适当的设置的大一点。

(3)使用闪回数据库的限制

        在以下几种情况下不能使用闪回数据库的特性:

  1. 如果数据文件被删除或者缩短
  2. 如果在闪回时间范围之内复原或者重建了一个控制文件
  3. 在resetlogs操作之前
  4. 表空间被删除

1.2 使用闪回数据库技术之前的准备

        打开闪回数据库功能

(1)确保数据库处于归档模式

archive log list# 配置归档模式:
startup mount
alter database archivelog;

(2)查看快闪恢复区的位置和设置的大小(闪回日志存储的位置和空间的大小)

show parameter db_recovery_file_dest;

(3)启用闪回数据库功能

alter database flashback on;

        启动之后我们可以通过试图v$database查看启动的状态。

select dbid,name,flashback_on from v$database;

(4)通过试图查看最多能够闪回的时间以及修改能闪回的最大天数

        设置参数DB_FLASHBACK_RETENTION_TARGET,该参数默认值为1440分钟,表示可以将数据库闪回到过去的时间,也就是默认可以闪回一天前的数据。

show parameter db_flashback_retention;
# 我们可以动态的修改这个参数的值,使的数据库可以闪回到更长的时间,比如1个月 24*60*30=43200
alter system set db_flashback_retention_target=43200 scope=both;

(5)查看系统时间

select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual;

(6)查看我们能够闪回到的最早的scn号 和最早的时间,并且评估闪回恢复区的大小

select * from v$flashback_database_log;# 查看能闪回到的最早时间
select to_char(oldest_flashback_time,'yyyy-mm-dd hh24:mi:ss') from v$flashback_database_log;

1.3 闪回数据库的方法

1.3.1 在RMAN下(3种方法)

(1)使用to_date将数据库闪回到指定的时间点

RMAN>flashback database to time=to_date('2017-06-29 12:30:00','yyyy-mm-dd hh24:mi:ss');

(2)将数据库闪回到指定的SCN,该方法一般不使用,因为SCN号一般不会去查询

这篇关于【云原生进阶之数据库技术】第二章-Oracle-原理-4.6.3.3-闪回数据库技术的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1043581

相关文章

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

从基础到进阶详解Pandas时间数据处理指南

《从基础到进阶详解Pandas时间数据处理指南》Pandas构建了完整的时间数据处理生态,核心由四个基础类构成,Timestamp,DatetimeIndex,Period和Timedelta,下面我... 目录1. 时间数据类型与基础操作1.1 核心时间对象体系1.2 时间数据生成技巧2. 时间索引与数据

Oracle修改端口号之后无法启动的解决方案

《Oracle修改端口号之后无法启动的解决方案》Oracle数据库更改端口后出现监听器无法启动的问题确实较为常见,但并非必然发生,这一问题通常源于​​配置错误或环境冲突​​,而非端口修改本身,以下是系... 目录一、问题根源分析​​​二、保姆级解决方案​​​​步骤1:修正监听器配置文件 (listener.

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

Nacos注册中心和配置中心的底层原理全面解读

《Nacos注册中心和配置中心的底层原理全面解读》:本文主要介绍Nacos注册中心和配置中心的底层原理的全面解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录临时实例和永久实例为什么 Nacos 要将服务实例分为临时实例和永久实例?1.x 版本和2.x版本的区别

Java中的登录技术保姆级详细教程

《Java中的登录技术保姆级详细教程》:本文主要介绍Java中登录技术保姆级详细教程的相关资料,在Java中我们可以使用各种技术和框架来实现这些功能,文中通过代码介绍的非常详细,需要的朋友可以参考... 目录1.登录思路2.登录标记1.会话技术2.会话跟踪1.Cookie技术2.Session技术3.令牌技

apache的commons-pool2原理与使用实践记录

《apache的commons-pool2原理与使用实践记录》ApacheCommonsPool2是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能,这篇文章主... 目录一、核心原理与组件二、使用步骤详解(以数据库连接池为例)三、高级配置与优化四、典型应用场景五、注意事

Druid连接池实现自定义数据库密码加解密功能

《Druid连接池实现自定义数据库密码加解密功能》在现代应用开发中,数据安全是至关重要的,本文将介绍如何在​​Druid​​连接池中实现自定义的数据库密码加解密功能,有需要的小伙伴可以参考一下... 目录1. 环境准备2. 密码加密算法的选择3. 自定义 ​​DruidDataSource​​ 的密码解密3