成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Oracle基于數據挖掘的不完全恢復

運維 數據庫運維
由于某種誤操作需要恢復數據庫。當然我們都知道,假如自己之前有備份數據庫可以用rman進行恢復,但是這樣的情況就會恢復倒備份的時刻狀態,而不是誤操作的時候的狀態,也可以叫做造成恢復過度了。于是我們可以用不完全恢復。

Oracle

【引自wzl_up的博客】由于某種誤操作需要恢復數據庫。當然我們都知道,假如自己之前有備份數據庫可以用rman進行恢復,但是這樣的情況就會恢復倒備份的時刻狀態,而不是誤操作的時候的狀態,也可以叫做造成恢復過度了。于是我們可以用不完全恢復。

注意:不完全恢復是需要關閉數據庫的,所以對于7*24的數據庫不適用,而且在誤操作之前是要有備份的。

下面我們來模擬數據誤操作以后的不完全恢復。

1. 備份數據庫

  1. RMAN> backup database
  2.  
  3. Starting backup at 10-APR-17 
  4. using channel ORA_DISK_1 
  5. channel ORA_DISK_1: starting full datafile backup set 
  6. channel ORA_DISK_1: specifying datafile(s) in backup set 
  7. input datafile file number=00001 name=/u01/oracle/oradata/orcl/system01.dbf 
  8. input datafile file number=00002 name=/u01/oracle/oradata/orcl/sysaux01.dbf 
  9. input datafile file number=00005 name=/u01/oracle/oradata/orcl/user02.dbf 
  10. input datafile file number=00006 name=/u01/oracle/oradata/orcl/tmpspace0327 
  11. input datafile file number=00007 name=/u01/oracle/oradata/orcl/undotbs02.dbf 
  12. input datafile file number=00008 name=/u01/oracle/oradata/orcl/example.dbf 
  13. input datafile file number=00004 name=/u01/oracle/oradata/orcl/users01.dbf 
  14. channel ORA_DISK_1: starting piece 1 at 10-APR-17 
  15. channel ORA_DISK_1: finished piece 1 at 10-APR-17 
  16. piece handle=/tmp/0us1cc3q_1_1 tag=TAG20170410T225138 comment=NONE 
  17. channel ORA_DISK_1: backup set complete, elapsed time: 00:01:25 
  18. channel ORA_DISK_1: starting full datafile backup set 
  19. channel ORA_DISK_1: specifying datafile(s) in backup set 
  20. including current control file in backup set 
  21. including current SPFILE in backup set 
  22. channel ORA_DISK_1: starting piece 1 at 10-APR-17 
  23. channel ORA_DISK_1: finished piece 1 at 10-APR-17 
  24. piece handle=/tmp/0vs1cc6f_1_1 tag=TAG20170410T225138 comment=NONE 
  25. channel ORA_DISK_1: backup set complete, elapsed time: 00:00:02 
  26. Finished backup at 10-APR-17  

2 .刪數據(完全刪除)

  1. SQL> drop table emp purge; 
  2.  
  3. Table dropped.  

3. 數據挖掘

數據不完全恢復的時候我們要知道scn或者時間點。需要從日志挖掘中找。

  1. SQL> desc dbms_logmnr; 
  2. PROCEDURE ADD_LOGFILE 
  3.  Argument Name          Type            In/Out Default
  4.  ------------------------------ ----------------------- ------ -------- 
  5.  LOGFILENAME            VARCHAR2        IN 
  6.  OPTIONS            BINARY_INTEGER      IN     DEFAULT 
  7. # 在dbms_logmnr這個包中有一個過程ADD_LOGFILE ,這個就是需要把挖掘的日志添加進去,再打開挖掘,可以看到參數只需要用一個logfilename ,日志文件名,所以我們需要找到刪除數據的時候適用的日志文件是哪個 
  8. SQL> select group#,members,status from v$log; 
  9.  
  10.     GROUP#    MEMBERS STATUS 
  11. ---------- ---------- ---------------- 
  12.      1      1 CURRENT 
  13.      2      1 INACTIVE 
  14.      3      1 INACTIVE 
  15. # 可以看出當前適用的日志文件是1 
  16. SQL> select group#,member,status from v$logfile; 
  17.  
  18.     GROUP
  19. ---------- 
  20. MEMBER                                     STATUS 
  21. ---------------------------------------------------------------------- ------- 
  22.      3 
  23. /u01/oracle/oradata/orcl/redo03.log 
  24.  
  25.      2 
  26. /u01/oracle/oradata/orcl/redo02.log 
  27.  
  28.      1 
  29. /u01/oracle/oradata/orcl/redo01.log 
  30. # 看以看出日志文件1 的名字是‘/u01/oracle/oradata/orcl/redo01.log’  

把日志文件添加進挖掘里面

  1. SQL> exec dbms_logmnr.add_logfile('/u01/oracle/oradata/orcl/redo01.log'); 
  2.  
  3. PL/SQL procedure successfully completed.  

啟動日志挖掘

  1. SQL> desc dbms_logmnr; 
  2. PROCEDURE START_LOGMNR 
  3.  Argument Name          Type            In/Out Default
  4.  ------------------------------ ----------------------- ------ -------- 
  5.  STARTSCN           NUMBER          IN     DEFAULT 
  6.  ENDSCN             NUMBER          IN     DEFAULT 
  7.  STARTTIME          DATE            IN     DEFAULT 
  8.  ENDTIME            DATE            IN     DEFAULT 
  9.  DICTFILENAME           VARCHAR2        IN     DEFAULT 
  10.  OPTIONS            BINARY_INTEGER      IN     DEFAULT 
  11. # 我們可以看到包dbms_logmnr里面有一個start_logmnr 過程,用這個過程啟動挖掘 
  12. SQL> execute dbms_logmnr.START_LOGMNR(options=>dbms_logmnr.dict_from_online_catalog); 
  13.  
  14. PL/SQL procedure successfully completed. 
  15. # 啟動挖掘成功  

從挖掘中找到誤操作數據當時的scn和時間,在v$logmnr_contents;

  1. SQL> select scn,to_char(TIMESTAMP,'yyyy-mm-dd hh24:mi:ss'TIMESTAMP,SQL_REDO,SQL_UNDO from v$logmnr_contents where table_name = 'EMP'
  2.  
  3.        SCN TIMESTAMP        SQL_REDO         SQL_UNDO 
  4. ---------- -------------------- -------------------- -------------------- 
  5.    2507301 2017-04-10 22:54:49  drop table emp purge  

到此為止,我們已經挖掘成功,找到scn和時間點

注意:如果用時間點恢復的時候要減1秒

最后關閉數據挖掘

  1. SQL> exec dbms_logmnr.end_logmnr; 
  2.  
  3. PL/SQL procedure successfully completed.  

4. 不完全恢復

  1. RMAN> shutdown immediate; 
  2.  
  3. using target database control file instead of recovery catalog 
  4. database closed 
  5. database dismounted 
  6. Oracle instance shut down 
  7. #先關閉數據庫 
  8. RMAN> startup mount; 
  9.  
  10. connected to target database (not started) 
  11. Oracle instance started 
  12. database mounted 
  13.  
  14. Total System Global Area     584568832 bytes 
  15.  
  16. Fixed Size                     2230552 bytes 
  17. Variable Size                444597992 bytes 
  18. Database Buffers             130023424 bytes 
  19. Redo Buffers                   7716864 bytes 
  20. #啟動倒mount狀態下 
  21. RMAN> run{ 
  22. 2> set until scn 2507301; 
  23. 3> restore database
  24. 4> recover database
  25. 5> alter database open resetlogs; 
  26. 6> } 
  27.  
  28. executing command: SET until clause 
  29.  
  30. Starting restore at 10-APR-17 
  31. allocated channel: ORA_DISK_1 
  32. channel ORA_DISK_1: SID=137 device type=DISK 
  33.  
  34. channel ORA_DISK_1: starting datafile backup set restore 
  35. channel ORA_DISK_1: specifying datafile(s) to restore from backup set 
  36. channel ORA_DISK_1: restoring datafile 00001 to /u01/oracle/oradata/orcl/system01.dbf 
  37. channel ORA_DISK_1: restoring datafile 00002 to /u01/oracle/oradata/orcl/sysaux01.dbf 
  38. channel ORA_DISK_1: restoring datafile 00004 to /u01/oracle/oradata/orcl/users01.dbf 
  39. channel ORA_DISK_1: restoring datafile 00005 to /u01/oracle/oradata/orcl/user02.dbf 
  40. channel ORA_DISK_1: restoring datafile 00006 to /u01/oracle/oradata/orcl/tmpspace0327 
  41. channel ORA_DISK_1: restoring datafile 00007 to /u01/oracle/oradata/orcl/undotbs02.dbf 
  42. channel ORA_DISK_1: restoring datafile 00008 to /u01/oracle/oradata/orcl/example.dbf 
  43. channel ORA_DISK_1: reading from backup piece /tmp/0us1cc3q_1_1 
  44. channel ORA_DISK_1: piece handle=/tmp/0us1cc3q_1_1 tag=TAG20170410T225138 
  45. channel ORA_DISK_1: restored backup piece 1 
  46. channel ORA_DISK_1: restore complete, elapsed time: 00:01:15 
  47. Finished restore at 10-APR-17 
  48.  
  49. Starting recover at 10-APR-17 
  50. using channel ORA_DISK_1 
  51.  
  52. starting media recovery 
  53. media recovery complete, elapsed time: 00:00:01 
  54.  
  55. Finished recover at 10-APR-17 
  56.  
  57. database opened 
  58. # 用上面run{}腳本進行恢復,restore,recover,open resetlogs; 
  59. # 成功  

5. 驗證

  1. SQL> desc emp; 
  2.  Name                      Null?    Type 
  3.  ----------------------------------------- -------- ---------------------------- 
  4.  EMPNO                     NOT NULL NUMBER(4) 
  5.  ENAME                          VARCHAR2(10) 
  6.  JOB                            VARCHAR2(9) 
  7.  MGR                            NUMBER(4) 
  8.  HIREDATE                       DATE 
  9.  SAL                            NUMBER(7,2) 
  10.  COMM                           NUMBER(7,2) 
  11.  DEPTNO                         NUMBER(2) 
  12.  
  13. SQL> select count(*) from emp; 
  14.  
  15.   COUNT(*) 
  16. ---------- 
  17. # 被刪除的emp表恢復成功  

6. 重新備份數據庫

注意:恢復倒誤操作時刻成功了,但是誤操作之后做的事情就會丟失,所以要謹慎,而且需要關閉數據。

在oracle11g 中還可以在線克隆的方式避免關閉數據庫:

方法大致步驟:

1) 在線克隆一個備庫

2)在備庫中進行不完全恢復

3) 把備庫中部完全恢復成功的數據拷貝到主庫

這樣既可以不用關閉數據庫,也解決了不完全恢復有可能造成的部分數據丟失。具體操作演示這里就不說了。

責任編輯:龐桂玉 來源: wzl_up的博客
相關推薦

2011-08-30 09:35:10

OracleRMAN不完全恢復基于時間恢復

2011-08-30 09:50:22

OracleRMAN不完全恢復基于SCN恢復

2011-08-30 10:02:18

OracleRMAN不完全恢復基于日志序列號恢復

2024-01-02 16:43:58

2015-09-01 10:42:15

編程規范完全指南

2015-10-10 10:02:44

程序員面試指南

2021-06-01 06:03:28

Css前端CSS 特效

2014-09-19 10:03:18

Chrome

2011-08-01 14:50:10

日志挖掘數據庫

2011-06-29 10:03:33

Qt Configure

2024-01-12 10:16:53

2021-05-06 07:26:55

CSS 文字動畫技巧

2021-02-09 00:46:45

區塊鏈加密貨幣工具

2009-11-18 09:39:06

Oracle介質恢復

2021-05-20 11:45:16

數據庫中間件架構

2021-08-18 10:28:09

MySQL SQL 語句數據庫

2019-04-12 15:00:11

2017-04-19 20:10:20

SQLJOIN

2019-07-04 08:47:57

JavaScript瀏覽器技術

2019-08-18 22:45:22

編程Rust語言
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美一区二区在线观看 | 日韩在线小视频 | 国产91久久精品一区二区 | 天天综合国产 | 黄色大片观看 | 欧美一级久久 | 在线一区二区三区 | 亚洲成人一区 | 中文字幕在线观看av | 国产精品成人久久久久 | 成人免费一区二区 | 福利久久| 91免费看片神器 | 精产国产伦理一二三区 | 成人不卡视频 | 欧美日韩中文在线 | 精品一区二区三区免费视频 | 在线中文视频 | 天堂中文在线播放 | 免费观看成人av | 亚洲欧美日韩精品久久亚洲区 | 亚洲精品一区二区三区在线 | www久久av | 久久lu | 色婷婷亚洲国产女人的天堂 | 国产精品免费福利 | 宅男伊人 | 亚洲综合无码一区二区 | 亚洲成人毛片 | 国产精品九九九 | 亚洲欧美日韩电影 | 国产在线小视频 | 亚洲综合色自拍一区 | 久久久精品视频免费看 | 黄页网址在线观看 | 欧美成人视屏 | 伊人狠狠 | 久久久www成人免费无遮挡大片 | 久久亚洲国产精品日日av夜夜 | 日韩精品在线视频 | 91久久久久久久久久久久久 |