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

資料庫移轉服務會運用 Oracle 資料庫內建的 Oracle LogMiner API,查詢封存的重做記錄檔。這些檔案包含資料庫活動記錄的相關資訊,每個 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;