暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Oracle数据库的闪回操作

原创 逆风飞翔 2023-01-16
1828

--1、查询执行过SQL语句,确定快照的时间
SELECT R.FIRST_LOAD_TIME,R.SQL_TEXT,R.* FROM V$SQLAREA R
WHERE R.SQL_TEXT LIKE '%ABOUT YOUR SQL%' ORDER BY R.FIRST_LOAD_TIME DESC;
--2、查询基于指定时间的数据快照
SELECT * FROM t1 AS OF TIMESTAMP TO__TIMESTAMP('2019-02-05 20:00:00', ' yyyy-mm-dd hh24:mi:ss');
--以当前时间为准, 125分钟之前的数据快照
SELECT * FROM t1 AS OF TIMESTAMP SYSDATE-125 / 1440

 一、闪回原理

  在启用闪回数据时,会将修改过的块的前映像作为闪回数据库日志保存在闪回恢复区中,如出现逻辑坏块或用户错误操作需要恢复到过去的时间点,闪回数据库将还原数据库的前映像,然后使用归档日志和redo前滚到期望恢复的时间点,因为无需还原数据库的数据文件,所有此过程速度比较传统的还原恢复通常快很多。

  1.1 闪回限制:
    ① Flashback Database 不能解决Media Failure, 这种错误RMAN恢复仍是唯一选择
    ② 如果删除了数据文件或者利用Shrink技术缩小数据文件大小,这时不能用Flashback Database技术回退到改变之前的状态,这时候就必须先利用RMAN把删除之前或者缩小之前的文件备份restore出来,然后利用Flashback Database执行剩下的Flashback Datbase。
    ③ 如果控制文件是从备份中恢复出来的,或者是重建的控制文件,也不能使用Flashback Database。
    ④ 使用Flashback Database锁能恢复到的最早的SCN,取决与Flashback Log中记录的最早SCN。

  1.2 配置闪回参数:

  闪回数据库相关参数:
     ① db_recovery_file_dest #决定闪回恢复区路径
     ② db_recovery_file_dest_size #决定闪回恢复区大小
     ③ db_flashback_retention_target #保留恢复最近多长时间的数据,单位为分钟。
  闪回相关视图:
     ① V$restore_point #闪回点
     ② V$FLASHBACK_DATABASE_LOG #闪回日终信息
     ③ V$FLASHBACK_DATABASE_STAT

     ④ v$flash_recovery_area_usage; #闪回区使用率

  1.3 开启归档和闪回功能:   

  SQL> SELECT flashback_on, force_logging, log_mode FROM v$database;
     FLASHBACK_ON FORCE_LOGGING LOG_MODE
     ------------------ ------------- ------------
      NO NO NOARCHIVELOG   


 开启闪回和归档方法:
  SQL>shutdown immediate;
  SQL>startup mount;
  SQL>alter database archivelog;#开启归档
  --SQL>alter database archivelog off ;#关闭归档功能
  SQL>alter database flashback on; #开启闪回功能
  --SQL>alter database flashback off; #关闭闪回功能
  SQL>alter database open; #打开数据库
  SQL>alter database force logging; #强制写日志

   1.4 闪回参数设置:    

  alter system set db_recovery_file_dest_size=5G scope=both;
  alter system set db_recovery_file_dest='/home/app/flash_recovery_area' scope=both;
  alter system set db_flashback_retention_target=2880;
 二、闪回数据库

  闪回步骤:

    ① 关闭数据库
    ② 启动数据库到mount状态[exclusive模式]
    ③ 闪回至某个时间点,SCN或还原点
    ④ 使用resetlogs打开数据库
  2.1 通过还原点闪回
    通过v$restore_point视图,可以查看当前数据库的闪回点。
     如果没有闪回点,可以创建个闪回点。方法如下:

    SQL>CREATE RESTORE POINT FLASHPOINT_1 GRARANTEE FLASHBACK DATABASE;#创建一个flashpoint_1的闪回点
   --进行相关的DML操作之后,闪回数据库到flashpoint_1状态
    SQL>SHUTDOWN IMMEDIATE #关闭数据库
    SQL>STARTUP MOUNT; #启到MOUNT状态
    SQL>FLASHBACK DATABASE TO RESTORE POINT FLASHPOINT_1; #闪回数据库到flashpoint_1闪回点
    SQL>ALTER DATABASE OPEN RESETLOGS; #打开数据库
   --删除归档日志
    RMAN TARGET /
    RMAN> DELETE ARCHIVELOG ALL; #删除所有归档日志
    RMAN> EXIT;
    SQL>DROP RESTORE POINT FLASHPOINT_1; #删除闪回点
    SQL>CREATE restore point FLASHPOINT_2 GRARANTEE FLASHBACK DATABASE; #新建闪回点

  2.2 通过SCN闪回

  SQL>SELECT DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER AS SCN_NO FROM DUAL;#获取当前数据库的SCN号
  --进行相关的DML操作之后,闪回数据库到SCN_NO状态
  SQL>SHUTDOWN IMMEDIATE #关闭数据库
  SQL>STARTUP MOUNT; #启到MOUNT状态
  SQL>FLASHBACK DATABASE TO SCN SCN_NO; #闪回数据库到闪回SCN_NO点
  SQL>ALTER DATABASE OPEN RESETLOGS; #打开数据库

   3 闪回数据库方法


  3.1 sqlplus下基于SCN闪回
   FLASHBACK DATABASE [<database_name>] TO SCN <system_change_number>
  3.2 sqlplus下基于时间戳闪回
   FLASHBACK DATABASE [<database_name>] TO TIMESTMP <system_timestamp_value>
  3.3 sqlplus下基于还原点闪回
   FLASHBACK DATABASE [<database_name>] TO RESTORE POINT <restore_point_name>
  3.4 RMAN下基于时间戳闪回
  RMAN> FLASHBACK DATABASE TO TIME = "TO_DATE('2013-12-08 12:45:00','YYYY-MM-DD HH24:MI:SS')"
  3.5 RMAN下基于SCN闪回
   RMAN> FLASHBACK DATABASE TO SCN=15809979;
  3.6 RMAN下基于:归档序号
  RMAN> FLASHBACK DATABASE TO SEQUENCE=192 THREAD=1;

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论