tft每日頭條

 > 科技

 > oracle rollback 機制

oracle rollback 機制

科技 更新时间:2024-11-20 04:33:24
概述

Flashback archive是Oracle 11g中推出的新曆史數據查詢新特性。對比過去的flashback query,flashback archive具有更強的時間準确和對象針對性。


一、Flashback Archive組件和FBDA進程

Flashback Archive特性是Oracle 11g中新推出的。每個新特性的推出,大都伴随着Oracle體系結構的不斷豐富和調整。

Oracle Total Recall組件是Flashback Archive功能的組件名稱。作為一個獨立組件在Oracle安裝的時候是會進行默認安裝的。從Oracle 官方資料中看,Flashback archive的作用是跟蹤一個或者多個數據表的曆史history數據變化,将其保存在一個或者多個表空間中。

借助Oracle 11g的Total Recall組件,Oracle會對數據表數據的變化進行自動的跟蹤記錄,記錄在設置的flashback archive裡。這個過程中,Oracle會進行相應的優化工作,将歸檔數據進行壓縮、分區。這樣做的效果可以在最小影響應用程序DML操作,并且對應用程序透明的情況下将數據進行歸檔保存。

為了實現Flashback Archive的功能,Oracle新引入了一個實例進程為FBDA(Flashback Archived Process)。該進程啟動時随着數據庫同時啟動。FBDA的作用如下:

1)FBDA首先從buffer cache中的undo表空間數據中查找過去數據表時間點數據。這點是與flashback query的特性相似;

2)如果要查找的數據在undo tablespace中,但是該塊沒有在buffer cache中。FBDA會從undo segment中獲取到數據塊,複制在buffer cache中;

3)當進行flashback archive操作的數據表發生修改的時候,FBDA會去将需要保存的數據存放在對應的适當内部數據表中;

oracle rollback 機制(一文看懂Oracle數據庫Flashback)1

注意,默認情況下fbda進程是不運行的。如果當前存在使用flashback archive功能的數據表,就會自動啟動fbda進程。

歸檔數據在flashback archive中是壓縮進行保存的,稱為history table曆史表。在内部,曆史表時被壓縮并且分區保存的。當保存的歸檔數據超過了設置的retention時間間隔,舊數據會被自動的删除purge。


二、Flashback Archive中的隐含表

Oracle 11g中的Flashback Archive本質是将數據表的變化信息加以保存,其中使用壓縮和分區表技術。當我們将一個數據表設置為flashback archive之後,會發現出現三個内部internal數據表。

SQL> desc SYS_FBA_TCRV_170708; Name Type Nullable Default Comments -------- -------------- -------- ------- -------- RID VARCHAR2(4000) Y STARTSCN NUMBER Y ENDSCN NUMBER Y XID RAW(8) Y OP VARCHAR2(1) Y SQL> desc SYS_FBA_HIST_170708 Name Type Nullable Default Comments -------------- -------------- -------- ------- -------- RID VARCHAR2(4000) Y STARTSCN NUMBER Y ENDSCN NUMBER Y XID RAW(8) Y OPERATION VARCHAR2(1) Y OWNER VARCHAR2(30) Y OBJECT_NAME VARCHAR2(128) Y …… EDITION_NAME VARCHAR2(30) Y SQL> desc SYS_FBA_DDL_COLMAP_170708; Name Type Nullable Default Comments ---------------------- ------------- -------- ------- -------- STARTSCN NUMBER Y ENDSCN NUMBER Y XID RAW(8) Y OPERATION VARCHAR2(1) Y COLUMN_NAME VARCHAR2(255) Y TYPE VARCHAR2(255) Y HISTORICAL_COLUMN_NAME VARCHAR2(255) Y

說明:

1)SYS_FBA_TCRV_XXX數據表負責記錄在特定的時間範圍(對應SCN範圍),進行特定操作的信息記錄;

2)SYS_FBA_HIST_XXX數據表的列包括數據行信息和對應存在的SCN範圍。如果一個數據表發生DML或者DDL操作,引起數據的變化會直接保存在該數據表中;

3)SYS_FBA_DDL_COLMAP_XXX數據表負責記錄數據表列DDL變化情況。從數據列的信息來看,就是一個特定的數據列的時間SCN範圍;


三、實驗

--創建Flashback Archive空間 --Flashback Archive是一種比較特殊的類型,需要我們進行一系列的配置工作。首先,我們在sys用戶下創建一個flashback archive存儲對象 create flashback archive flar1 tablespace USERS retention 1 year; --設置具有閃回歸檔功能的數據表 create user hwbtest identified by hwb default tablespace users; grant dba to hwbtest; conn hwbtest/hwb; create table t as select * from dba_objects; alter table t flashback archive flar1; --觀察到dba_flashback_archive_tables視圖的結果,建立了數據表T與flar1的關系 select * from dba_flashback_archive_tables;

oracle rollback 機制(一文看懂Oracle數據庫Flashback)2

flashback archive與flashback query很相像,都是利用指定過去的一個時間點(timestamp,scn)進行查詢。但是,flashback query是利用undo的負效應,将沒有被覆寫的數據返回給用戶。這種方式首先是對所有的數據表均有效果,另一個是時間有限,受到undo大小和數據庫事務頻繁度的影響。

而flashback archive則是将數據歸檔做到了數據庫的層面上。設置一塊專門的區域空間,稱之為flashback archive。這個區域是真實對應在表空間上可以進行存儲使用的。之後設置這塊區域的保留時間。

在數據表層面,可以選擇需要進行保留的數據表,讓其與flashback archive區域關聯,這樣在存儲區域中,就會保留各個時間點的鏡像數據。


四、腳本:Displays information about flashback data archives.

SET LINESIZE 150 ​ COLUMN owner_name FORMAT A20 COLUMN flashback_archive_name FORMAT A22 COLUMN create_time FORMAT A20 COLUMN last_purge_time FORMAT A20 ​ SELECT owner_name, flashback_archive_name, flashback_archive#, retention_in_days, TO_CHAR(create_time, 'DD-MON-YYYY HH24:MI:SS') AS create_time, TO_CHAR(last_purge_time, 'DD-MON-YYYY HH24:MI:SS') AS last_purge_time, status FROM dba_flashback_archive ORDER BY owner_name, flashback_archive_name;

oracle rollback 機制(一文看懂Oracle數據庫Flashback)3


五、腳本: Displays information about flashback data archives.

SET LINESIZE 150 ​ COLUMN owner_name FORMAT A20 COLUMN table_name FORMAT A20 COLUMN flashback_archive_name FORMAT A22 COLUMN archive_table_name FORMAT A20 ​ SELECT owner_name, table_name, flashback_archive_name, archive_table_name, status FROM dba_flashback_archive_tables ORDER BY owner_name, table_name;

oracle rollback 機制(一文看懂Oracle數據庫Flashback)4


六、腳本:Displays information about flashback data archives.

SET LINESIZE 150 ​ COLUMN flashback_archive_name FORMAT A22 COLUMN tablespace_name FORMAT A20 COLUMN quota_in_mb FORMAT A11 ​ SELECT flashback_archive_name, flashback_archive#, tablespace_name, quota_in_mb FROM dba_flashback_archive_ts ORDER BY flashback_archive_name;

oracle rollback 機制(一文看懂Oracle數據庫Flashback)5


總結

數據歸檔、offline是很多系統都需要有的特定需求。我們經常遇到這樣的需求:将曆史數據保留幾個月或者幾年待查。待查的情景是很少,但是我們如果從應用入手,就需要設計額外的數據表和業務處理流程。其中一個更麻煩的就是保留期過删數據的操作,相對較為複雜。

Flashback archive是Oracle可以使用在生産系統中直接使用的歸檔功能組件。如果開發設計使用這個組件進行歸檔,有若幹個好處。

  • 首先是透明化的歸檔操作,用戶不需要去關心進行歸檔的業務邏輯。隻要設置好了需要歸檔的數據表,按照查詢歸檔語法進行查找。就可以實現應用系統中最典型的歸檔查詢需要。
  • 其次是高效存儲個性。在flashback archive中,數據是保存在内部分區壓縮表中,各方面的屬性由Oracle進行控制管理。
  • 最後是保留期管理嚴格化。設置不同的flashback archive retention period,首先可以對不同的數據表适應使用不同的保留期。當數據超期之後,Oracle自動進行數據删除工作,不需要用戶進行幹預。

覺得有用的朋友多幫忙轉發哦!後面會分享更多devops和DBA方面的内容,感興趣的朋友可以關注下~

oracle rollback 機制(一文看懂Oracle數據庫Flashback)6

,

更多精彩资讯请关注tft每日頭條,我们将持续为您更新最新资讯!

查看全部

相关科技资讯推荐

热门科技资讯推荐

网友关注

Copyright 2023-2024 - www.tftnews.com All Rights Reserved