Oracle Undo 的配置
配置AUM,要先設定初始化引數unod_management,有兩個取值:
AUTO:表示採用AUM來管理undo
MANUAL:表示採用MUN來管理undo,要手工建立rollback segment
在AUM下,只要建立undo表空間,設定undo_tablespace初始化引數即可。
create undo tablespace Name datafile FileName size XM autoextend on;
alter system set undo_tablespace=Name;
在AUM下,如果在設定undo_tablespace時,指定了某個不存在的undo表空間,則例項啟動時報錯;
如果沒有設定undo_tablespace,則系統會查詢第一個可用的undo表空間;
如果沒有找到undo表空間,則使用位於系統表空間的rollback segment。
AUM採用的是事務繫結undo segment的演算法:
首先嚐試將每個undo segment繫結一個事務,即每個undo segment上只被一個事務使用;
如果不能發現完全空閒的(也就是沒有與任何事務繫結)undo segment,則嘗試將其他離線的undo segment聯機;
如果沒有可用的undo segment進行聯機,嘗試建立一個新的undo segment;
如果由於沒有可用空間,不能建立新的undo segment,則事務繫結演算法會嘗試找最早被使用的那個undo segment,這種情況下,不同的多個事務才會在一個相同的undo segment裡同時執行。
Undo Segment的收縮,由SMON完成:
每12小時會收縮一次,刪除狀態為idle狀態的extents;
前臺進行DML而需要undo時,發現空間不夠,則會喚醒SMON進行一次收縮。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/81227/viewspace-688376/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle Undo的作用Oracle
- oracle的undo的作用Oracle
- Oracle Undo的學習Oracle
- oracle的redo和undoOracle
- Oracle Redo and UndoOracle Redo
- Oracle undo 管理Oracle
- Oracle Undo SegmentOracle
- oracle undo管理Oracle
- oracle undo一Oracle
- 淺談Oracle的undo管理Oracle
- [zt] Oracle Undo的學習Oracle
- 關於oracle中的undoOracle
- oracle的undo的工作過程Oracle
- Oracle深入Undo探究Oracle
- Oracle UNDO引數Oracle
- oracle undo 使用分析Oracle
- Oracle In Memory Undo(IMU)Oracle
- Oracle In Memory Undo(轉)Oracle
- oracle undo系列(三)Oracle
- oracle undo系列(二)Oracle
- 關於oracle的undo_retentionOracle
- Oracle的redo 和undo的區別Oracle
- Oracle OCP(48):UNDO TABLESPACEOracle
- oracle undo分配規則Oracle
- oracle undo 表空間Oracle
- Oracle undo管理詳解Oracle
- Oracle 10gr2的後的undoOracle 10g
- 關於Oracle的redo和undo的理解Oracle
- MySQL InnoDB Undo表空間配置MySql
- Oracle 12c 新特性 - 臨時表undo(TEMP UNDO)Oracle
- Oracle 面試寶典-UNDO篇Oracle面試
- 【REDO】Oracle redo undo 學習Oracle Redo
- Oracle常見UNDO等待事件Oracle事件
- Oracle undo 表空間管理Oracle
- oracle 釋放undo空間Oracle
- Oracle UNDO引數詳解Oracle
- [Oracle Script] Undo Usage Per statusOracle
- [Oracle Script] Undo Usage Per sessionOracleSession