使用 Oracle 資料庫的重做記錄檔

資料庫移轉服務會利用 Oracle LogMiner API (屬於 Oracle Database 的一部分) 來查詢封存的重做記錄檔。這些檔案包含資料庫活動記錄的相關資訊。每個 Oracle 資料庫都有一組線上重做記錄檔。資料庫中的所有交易記錄都會記錄在檔案中。

當目前的重做記錄檔旋轉 (或切換) 時,封存程序會 將這個檔案複製到封存儲存空間。同時,資料庫會將另一個檔案升級為目前的檔案。

資料庫移轉服務使用 Oracle LogMiner API 時,不會存取線上重做記錄檔,只會使用封存的記錄檔。存取封存的重做日誌檔案會導致遷移程序產生一些延遲。本頁面說明 Oracle 來源資料庫的建議設定,以控制延遲影響。

設定 Oracle 重做記錄檔的設定參數

這項設計對資料庫移轉服務的潛在延遲時間影響深遠。如果 Oracle 重做記錄檔經常切換或保持較小的大小 (例如 < 256MB),資料庫移轉服務就能更快速地複製變更。

您可以設定設定參數來控制記錄檔輪替頻率:

  • 大小:線上重做記錄檔的大小至少為 4 MB,預設大小則取決於作業系統。您可以建立新的線上記錄檔並捨棄舊的記錄檔,藉此修改記錄檔大小。

    如要查看線上重做記錄檔的大小,請執行下列查詢:

    SELECT GROUP#, STATUS, BYTES/1024/1024 MB FROM V$LOG
  • 時間:ARCHIVE_LAG_TARGET 參數會提供主要資料庫目前記錄的時間長度上限 (以秒為單位)。

    這並非確切的記錄切換時間,因為系統會考量封存記錄所需的時間。預設值為 0 (沒有上限),建議的合理值為 1800 (或 30 分鐘) 以下。

    您可以在初始化期間或資料庫運作期間,使用下列指令設定 ARCHIVE_LAG_TARGET 參數:

    • SHOW PARAMETER ARCHIVE_LAG_TARGET; 這個指令會顯示目前記錄跨越的秒數。
    • ALTER SYSTEM SET ARCHIVE_LAG_TARGET = number-of-seconds; 使用這個指令變更上限。

      例如,如要將上限設為 10 分鐘 (或 600 秒),請輸入 ALTER SYSTEM SET ARCHIVE_LAG_TARGET = 600;