全部產品
Search
文件中心

PolarDB:PolarDB PostgreSQL版(相容Oracle)間的遷移

更新時間:Mar 18, 2025

通過Data Transmission Service,可以實現PolarDB PostgreSQL版(相容Oracle)叢集間的遷移。

背景資訊

PolarDB PostgreSQL版(相容Oracle)作為一款企業級關係型資料庫管理系統,具有廣泛的應用和強大的社區支援。每個新版本的發布都帶來了許多改進和新特性,以提高效能、可用性和安全性。目前,升級到PolarDB PostgreSQL版(相容Oracle) 2.0版本可以顯著提升資料庫效能與使用體驗。

2.0版本引入了新的查詢最佳化演算法和儲存引擎,提高了查詢速度和並發處理能力,能夠更快地處理大量資料,提升資料庫的響應能力和效能。此外,2.0版本還引入了許多新的功能和增強功能,提供更好的使用者體驗和開發人員工具。例如,改進了對JSON資料類型的支援,使處理和查詢JSON資料更加便捷;豐富的監控和診斷工具,協助您更好地理解和最佳化資料庫的效能;加強了資料庫的安全性和可靠性,引入了更嚴格的存取控制策略和許可權管理功能,保護您的資料免受潛在的安全威脅;改進了備份和恢複功能,使您能夠更輕鬆地保護與復原資料。

升級到2.0版本還意味著您可以與PostgreSQL社區保持同步,提供更多的資源和支援,協助您解決問題並學習資料庫的最佳實務。強烈建議您升級到PolarDB PostgreSQL版(相容Oracle)2.0版本,充分利用其優勢。

遷移評估

如果您已經購買了PolarDB PostgreSQL版(相容Oracle) 1.0版本叢集,您可以在開始遷移前,通過遷移評估功能對叢集的相容性進行預校正,提前發現影響遷移進度的前置條件並處理,以降低遷移過程中的處理成本和資源成本。

支援的地區

當前支援遷移評估功能的地區有:

華東1(杭州)、華東2(上海)、華南1(深圳)、華北2(北京)、華北3(張家口)、華北6(烏蘭察布)、西南1(成都)、中國(香港)、日本(東京)、新加坡、印尼(雅加達)、美國(矽谷)、美國(維吉尼亞)。

影響

遷移評估不會對業務造成影響。

建立遷移評估任務

  1. 登入PolarDB控制台

  2. 在左上方,選擇叢集所在地區。

  3. 建立遷移評估任務。PolarDB提供了兩種建立遷移評估任務的入口:

    1. 叢集列表頁建立:在叢集列表頁左上方單擊遷移/升級評估按鈕。

      f741374229beacceee41de1406e3146b

    2. 遷移/升級頁建立:在遷移/升級頁左上方單擊遷移/升級評估按鈕。

      bc27346fe35a0fce09344544b84d85d8

  4. 在彈出的遷移/升級評估對話方塊,填寫遷移評估任務的相關參數,然後單擊下一步

    參數名稱

    參數說明

    建立方式

    選擇從PolarDB升級

    源PolarDB版本

    選擇Oracle 1.0

    源PolarDB執行個體

    選擇要遷移的源Oracle 1.0叢集。

    目標資料庫引擎

    選擇Oracle 2.0

    資料庫名稱

    選擇要遷移的來源資料庫。

  5. 遷移/升級評估對話方塊,您可以查看關於叢集相容性的整體描述和詳細資料。

    1. 查看整體描述。

      3a515ca73a87b7c94447c2b31be9925d

    2. 查看詳細資料。

      dcda2a6170011b2215a7ccc37921cf6c

      說明

      您需要重點關注相容性評估結果中的不相容對象。

      • 對於Oracle資料庫原生對象,可以忽略。

      • 對於業務SQL中涉及的不相容對象,需要進行改造適配。如果業務側無法改造,您可以聯絡我們,研發工程師將協助您處理。

管理遷移評估任務

對於已經建立的評估任務,您可以前往遷移/評估頁面查看評估詳情。

說明

建立的遷移評估任務有效期間為7天,到期後將自動刪除。若您的遷移評估任務已到期,您可重新建立新的評估任務。

前提條件

  • 已建立源和目標PolarDB PostgreSQL版(相容Oracle)資料庫叢集,詳情請參見建立PolarDB PostgreSQL版(相容Oracle)叢集

  • 已將源和目標PolarDB PostgreSQL版(相容Oracle)叢集的wal_level參數值設定為logical。設定方式,請參見設定叢集參數

  • 目標資料庫的儲存空間,需大於來源資料庫已使用的儲存空間。

注意事項

說明
  • 在庫表結構同步過程中,DTS會將來源資料庫中的外鍵同步到目標資料庫。

  • 在全量同步和增量同步處理過程中,DTS會以Session層級暫時禁用約束檢查以及外鍵級聯操作。若任務運行時源庫存在串聯更新、刪除操作,可能會導致資料不一致。

類型

說明

源庫限制(PolarDB 1.0)

  • 頻寬要求:源庫所屬的伺服器需具備足夠的出口頻寬,否則將影響資料移轉速率。

  • 待遷移的表需具備主鍵或唯一約束,且欄位具有唯一性,否則可能會導致目標資料庫中出現重複資料。

  • 如遷移對象為表層級,且需進行編輯(如表列名映射),則單次遷移任務僅支援遷移至多1000張表。當超出數量限制,任務提交後會顯示請求報錯,此時建議您拆分待遷移的表,分批配置多個任務,或者配置整庫的遷移任務。

  • 如需進行增量遷移,WAL日誌:

    • 需開啟。

    • 如為增量遷移任務,DTS要求來源資料庫的WAL日誌儲存24小時以上,如為全量遷移和增量遷移任務,DTS要求來源資料庫的WAL日誌至少保留7天以上(您可在全量遷移完成後將WAL日誌儲存時間設定為24小時以上),否則DTS可能因無法擷取WAL日誌而導致任務失敗,極端情況下甚至可能會導致資料不一致或丟失。由於您所設定的WAL日誌儲存時間低於DTS要求的時間進而導致的問題,不在DTS的SLA保障範圍內。

  • 源庫的操作限制:

    • 在庫表結構遷移和全量遷移階段,請勿執行庫或表結構變更的DDL操作,否則資料移轉任務會失敗。

    • 如僅執行全量資料移轉,請勿向源執行個體中寫入新的資料,否則會導致源和目標資料不一致。為即時保持資料一致性,建議選擇結構遷移、全量資料移轉和增量資料移轉。

    • 為保障遷移任務的正常進行,避免主備切換導致的邏輯訂閱中斷,需要PolarDB PostgreSQL版(相容Oracle)支援並開啟Logical Replication Slot Failover。設定方式,請參見邏輯複製槽容錯移轉(Logical Replication Slot Failover)

  • 若源庫有長事務,且執行個體包含增量遷移任務,則可能會導致源庫長事務提交前的預寫記錄檔WAL無法清理而堆積,從而造成源庫磁碟空間不足。

其他限制

  • 單個資料移轉任務只能遷移一個資料庫,如需遷移多個資料庫,您需要為每個資料庫配置資料移轉任務。

  • 在增量資料移轉過程中,如果遷移對象的選擇粒度為Schema,在待遷移的Schema中建立了新的表或使用RENAME命令重建了待遷移的表,您需要在對該表寫入資料前執行ALTER TABLE schema.table REPLICA IDENTITY FULL;命令。

    說明

    將上述命令中的schematable替換成真實的Schema名和表名。

  • 為保障增量資料移轉延遲時間展示的準確性,DTS會在源庫中新增一張表,表名為dts_postgres_heartbeat,結構及內容如下圖所示。表結構

  • 增量資料移轉期間,DTS會在源庫中建立首碼為dts_sync_的replication slot用於複製資料。通過該replication slot,DTS可以擷取源庫15分鐘內的增量日誌。

    說明
    • DTS釋放執行個體後會主動刪除該replication slot,如果您在遷移期間修改了資料庫密碼,或者刪除了DTS的訪問IP白名單,則會導致該replication slot無法自動刪除,此時需要您在源庫手動刪除,避免其持續累積佔用磁碟空間導致PolarDB PostgreSQL版(相容Oracle)不可用。

    • 當釋放遷移任務或遷移失敗時,DTS會主動清理該replication slot;如果PolarDB PostgreSQL版(相容Oracle)發生了主備切換,則需要您登入備庫來手動清理。

  • 執行資料移轉前需評估源庫和目標庫的效能,同時建議業務低峰期執行資料移轉。否則全量資料移轉時DTS佔用源和目標庫一定讀寫資源,可能會導致資料庫的負載上升。

  • 由於全量資料移轉會並發執行INSERT操作,導致目標資料庫的表產生片段,因此全量遷移完成後目標資料庫的表格儲存體空間會比源執行個體的表格儲存體空間大。

  • 請確認DTS對資料類型為FLOAT或DOUBLE的列的遷移精度是否符合業務預期。DTS會通過ROUND(COLUMN,PRECISION)來讀取這兩類列的值。如果沒有明確定義其精度,DTS對FLOAT的遷移精度為38位,對DOUBLE的遷移精度為308位。

  • DTS會嘗試恢複七天之內遷移失敗任務。因此業務切換至目標執行個體前,請務必結束或釋放該任務,或者將DTS訪問目標執行個體帳號的寫入權限用revoke命令回收掉。避免該任務被自動回復後,源端資料覆蓋目標執行個體的資料。

  • DTS的校正對象為資料內容,暫不支援Sequence等中繼資料的校正,您需要自行校正。

  • 由於業務切換到目標端後,新寫入的Sequence不會按照源庫的Sequence最大值作為初始值去遞增,您需要在業務切換前,在源庫中查詢對應Sequence的最大值,然後在目標庫中將其作為對應Sequence的初始值。查詢源庫Sequence值的相關命令如下:

    do language plpgsql $$
    DECLARE
     nsp name;
     rel name;
     val int8;
    BEGIN
     for nsp,rel in select nspname,relname from pg_class t2 , pg_namespace t3 where t2.relnamespace=t3.oid and t2.relkind='S' and relowner != 10
     loop
     execute format($_$select last_value from %I.%I$_$, nsp, rel) into val;
     raise notice '%',
     format($_$select setval('%I.%I'::regclass, %s);$_$, nsp, rel, val+1);
     end loop;
    END;
    $$;

費用說明

同步類型

鏈路配置費用

庫表結構同步和全量資料同步

不收費。

增量資料同步

收費,詳情請參見計費概述

遷移類型說明

遷移類型

說明

結構遷移

DTS將遷移對象的結構定義遷移到目標庫。目前DTS支援的對象包括:表、視圖、同義字、觸發器、預存程序、儲存函數、包、自訂類型。

說明

暫不相容觸發器。建議您刪除源庫的觸發器,以避免因觸發器而導致資料不一致的問題。詳情請參見源庫存在觸發器時如何配置同步或遷移作業

全量資料移轉

DTS會將源庫中遷移對象的存量資料,全部遷移至目標庫。

說明

在結構遷移和全量資料移轉完成之前,請勿對遷移對象執行DDL操作,否則可能導致遷移失敗。

增量資料移轉

DTS在全量資料移轉的基礎上輪詢並捕獲源庫產生的WAL日誌,將源庫的累加式更新資料移轉到目標庫中。

通過增量資料移轉可以實現在應用不停服的情況下,平滑地完成資料移轉。

支援同步的SQL操作

操作類型

SQL動作陳述式

DML

INSERT、UPDATE、DELETE

DDL

重要

來源資料庫帳號需為高許可權帳號時,同步任務支援如下DDL操作:

  • CREATE TABLE、DROP TABLE

  • ALTER TABLE(包括RENAME TABLE、ADD COLUMN、ADD COLUMN DEFAULT、ALTER COLUMN TYPE、DROP COLUMN、ADD CONSTRAINT、ADD CONSTRAINT CHECK、ALTER COLUMN DROP DEFAULT)

  • TRUNCATE TABLE(源庫PolarDB PostgreSQL版(相容Oracle)的資料庫引擎需為1.0及以上版本)

  • CREATE INDEX ON TABLE

重要
  • 不支援同步DDL中包含的附加資訊,如CASCADE或RESTRICT等。

  • 不支援同步使用SET session_replication_role = replica命令的會話中的DDL。

  • 若源庫單次提交的多條SQL中同時包含DML和DDL,則該DDL不會被同步。

  • 若源庫單次提交的多條SQL中包含非同步對象的DDL,則該DDL不會被同步。

資料庫帳號的許可權要求

資料庫

許可權要求

PolarDB PostgreSQL版(相容Oracle)叢集

高許可權帳號。

目標PolarDB PostgreSQL版(相容Oracle)叢集

資料庫Owner許可權。

重要

資料庫Owner在建立資料庫時已指定。資料庫帳號建立及授權方法,請參見建立資料庫帳號

配置步驟

  1. 進入目標地區的遷移工作清單頁面(二選一)。

    通過DTS控制台進入

    1. 登入Data Transmission Service控制台

    2. 在左側導覽列,單擊資料移轉

    3. 在頁面左上方,選擇遷移執行個體所屬地區。

    通過DMS控制台進入

    說明

    實際操作可能會因DMS的模式和布局不同,而有所差異。更多資訊。請參見極簡模式控制台自訂DMS介面布局與樣式

    1. 登入Data Management服務

    2. 在頂部功能表列中,選擇Data + AI > 資料轉送(DTS) > 資料移轉

    3. 遷移任務右側,選擇遷移執行個體所屬地區。

  2. 單擊建立任務,配置源庫及目標庫資訊。

    說明

    資料類型都選擇PolarDB(相容Oracle)。

    類別

    配置

    說明

    任務名稱

    DTS會自動產生一個任務名稱,建議配置具有業務意義的名稱(無唯一性要求),便於後續識別。

    源庫資訊(PolarDB 1.0)

    選擇已有的DMS資料庫執行個體

    您可以按實際需求,選擇是否使用已有執行個體。

    • 如使用已有執行個體,下方資料庫資訊將自動填入,您無需重複輸入。

    • 如不使用已有執行個體,您需要輸入下方的資料庫資訊。

    資料庫類型

    選擇PolarDB(相容Oracle)

    接入方式

    選擇雲執行個體

    執行個體地區

    選擇源PolarDB PostgreSQL版(相容Oracle)叢集所屬地區。

    是否跨阿里雲帳號

    本樣本為同一阿里雲帳號間同步,選擇不跨帳號

    執行個體ID

    選擇源PolarDB PostgreSQL版(相容Oracle)叢集ID。

    資料庫名稱

    填入PolarDB PostgreSQL版(相容Oracle)資料庫的名稱。

    資料庫帳號

    填入PolarDB PostgreSQL版(相容Oracle)叢集的資料庫帳號。

    資料庫密碼

    填入該資料庫帳號對應的密碼。

    目標庫資訊(PolarDB 2.0)

    選擇已有的資料庫執行個體

    您可以按實際需求,選擇是否使用已有執行個體。

    • 如使用已有執行個體,下方資料庫資訊將自動填入,您無需重複輸入。

    • 如不使用已有執行個體,您需要輸入下方的資料庫資訊。

    資料庫類型

    選擇PolarDB(相容Oracle)

    接入方式

    選擇雲執行個體

    執行個體地區

    選擇目標PolarDB PostgreSQL版(相容Oracle)叢集所屬地區。

    執行個體ID

    選擇目標PolarDB PostgreSQL版(相容Oracle)叢集ID。

    資料庫名稱

    填入目標PolarDB PostgreSQL版(相容Oracle)資料庫的名稱。

    資料庫帳號

    填入目標PolarDB PostgreSQL版(相容Oracle)叢集的高許可權資料庫帳號,帳號建立及授權方式,請參見建立資料庫帳號

    資料庫密碼

    填入該資料庫帳號對應的密碼。

  3. 配置完成後,單擊頁面下方的測試連接以進行下一步

    DTS任務會自動將對應地區DTS服務的IP地址添加到阿里雲資料庫執行個體的白名單中。

    警告
    DTS自動添加或您手動添加DTS服務的公網IP位址區段可能會存在安全風險,一旦使用本產品代表您已理解和確認其中可能存在的安全風險,並且需要您做好基本的安全防護,包括但不限於加強帳號密碼強度防範、限制各網段開放的連接埠號碼、內部各API使用鑒權方式通訊、定期檢查並限制不需要的網段,或者使用通過內網(專線/VPN網關/智能網關)的方式接入。
  4. 配置任務對象及進階配置。

    說明

    源庫對象會列出所有的命名空間,根據需要選擇自己遷移的命名空間即可。

    配置

    說明

    同步類型

    固定選中增量同步處理。預設情況下,您還需要同時選中庫表結構同步全量同步。預檢查完成後,DTS會將源執行個體中待同步對象的全量資料在目的地組群中初始化,作為後續增量同步處理資料的基準資料。

    說明

    同步類型需要全選。

    同步拓撲

    • 單向拓撲:只建立源庫到目標庫的單向同步鏈路,包括存量資料及增量同步處理鏈路。

    • 雙向同步:建立源庫到目標庫的雙向同步鏈路,同時進行源庫到目標庫的增量同步處理,以及目標庫到源庫的反向迴流。

    說明

    反向迴流只支援資料同步,不支援DDL操作。

    目標已存在表的處理模式

    • 預檢查並報錯攔截:檢查目標資料庫中是否有同名的表。如果目標資料庫中沒有同名的表,則通過該檢查專案;如果目標資料庫中有同名的表,則在預檢查階段提示錯誤,資料同步任務不會被啟動。

      說明

      如果目標庫中同名的表不方便刪除或重新命名,您可以更改該表在目標庫中的名稱,請參見庫表列名映射

    • 忽略報錯並繼續執行:跳過目標資料庫中是否有同名表的檢查項。

      警告

      選擇為忽略報錯並繼續執行,可能導致資料不一致,給業務帶來風險,例如:

      • 結構一致的情況下,如在目標庫遇到與源庫主鍵或唯一鍵的值相同的記錄:

        • 全量期間,DTS會保留目的地組群中的該條記錄,即源庫中的該條記錄不會同步至目標資料庫中。

        • 增量期間,DTS不會保留目的地組群中的該條記錄,即源庫中的該條記錄會覆蓋至目標資料庫中。

      • 表結構不一致的情況下,可能會導致無法初始化資料、只能同步部分列的資料或同步失敗,請謹慎操作。

    目標庫對象名稱大小寫策略

    您可以配置目標執行個體中同步對象的庫名、表名和列名的英文大小寫策略。預設情況下選擇DTS預設策略,您也可以選擇與源庫、目標庫預設策略保持一致。更多資訊,請參見目標庫對象名稱大小寫策略

    源庫對象

    源庫對象框中單擊待同步對象,然後單擊向右將其移動至已選擇對象框。

    說明

    同步對象選擇的粒度為庫、表、列。若選擇的同步對象為表或列,其他對象(如視圖、觸發器、預存程序)不會被同步至目標庫。

    已選擇對象

    • 如需更改單個同步對象在目標執行個體中的名稱,請右擊已選擇對象中的同步對象,設定方式,請參見庫表列名映射

    • 如需批量更改同步對象在目標執行個體中的名稱,請單擊已選擇對象方框右上方的大量編輯,設定方式,請參見庫表列名映射

    說明
    • 如需按庫或表層級選擇同步的SQL操作,請在已選擇對象中右擊待同步對象,並在彈出的對話方塊中選擇所需同步的SQL操作。支援的操作請參見支援同步的SQL操作

    • 如需設定WHERE條件過濾資料,請在已選擇對象中右擊待同步的表,在彈出的對話方塊中設定過濾條件。設定方法請參見設定過濾條件

  5. 單擊下一步進階配置,進行進階配置。

    配置

    說明

    選擇調度該任務的專屬叢集

    DTS專屬叢集是在某一地區由多台相同規格的ECS虛擬機器組成的叢集,用於管理和配置DTS遷移、同步和訂閱任務。相比DTS共用叢集,DTS專屬叢集具有資源獨享、穩定性更好、效能更優和成本更低的特點。詳情請參見什麼是DTS專屬叢集

    源庫、目標庫無法串連後的重試時間

    在同步任務啟動後,若源庫或目標庫串連失敗則DTS會報錯,並會立即進行持續的重試串連,預設持續重試時間為720分鐘,您也可以在取值範圍(10~1440分鐘)內自訂重試時間,建議設定30分鐘以上。如果DTS在設定的重試時間內重新串連上源庫、目標庫,同步任務將自動回復。否則,同步任務將會失敗。

    說明
    • 針對同源或者同目標的多個DTS執行個體,如DTS執行個體A和DTS執行個體B,設定網路重試時間時A設定30分鐘,B設定60分鐘,則重試時間以低的30分鐘為準。

    • 由於串連重試期間,DTS將收取任務運行費用,建議您根據業務需要自訂重試時間,或者在源和目標庫執行個體釋放後儘快釋放DTS執行個體。

    源庫、目標庫出現其他問題後的重試時間

    在同步任務啟動後,若源庫或目標庫出現非串連性的其他問題(如DDL或DML執行異常),則DTS會報錯並會立即進行持續的重試操作,預設持續重試時間為10分鐘,您也可以在取值範圍(1~1440分鐘)內自訂重試時間,建議設定10分鐘以上。如果DTS在設定的重試時間內相關操作執行成功,同步任務將自動回復。否則,同步任務將會失敗。

    重要

    源庫、目標庫出現其他問題後的重試時間的值需要小於源庫、目標庫無法串連後的重試時間的值。

    是否限制全量遷移速率

    全量遷移時會開啟對源庫的多並發讀取及對目標庫的多並發寫入,這一行為可能對使用者的資料庫造成一定的壓力,如果不希望對資料庫影響太大,可以限制遷移的速率上限。

    是否限制增量遷移速率

    增量遷移時會開啟對源庫的多並發讀取及對目標庫的多並發寫入,如果單庫的業務壓力較大,可能對另外一個庫也造成較大的寫入壓力;如果不希望對資料庫影響太大,可以限制遷移的速率上限。

    環境標籤

    用於標識DTS任務的重要程度,環境標籤不會對任務正常運行有任何影響。

    配置ETL功能

    選擇是否配置ETL功能。關於ETL的更多資訊,請參見什麼是ETL

    監控警示

    是否設定警示,當同步失敗或延遲超過閾值後,將通知警示連絡人。

    • 不設定:不設定警示。

    • 設定:設定警示,您還需要設定警示閾值和警示連絡人。更多資訊,請參見配置監控警示

  6. 單擊下一步資料校正,進行資料校正配置

    配置

    說明

    資料校正方式

    • 全量校正:對全部的資料進行校正。若您勾選了全量校正,您需要配置校正參數和校正對象,更多資訊,請參見在DTS同步或遷移執行個體中配置資料校正

    • 增量校正:固定選中,只校正資料轉送中增量部分的資料。

    • 結構校正:固定選中,對需要校正的對象進行結構校正。

  7. 儲存任務並進行預檢查。

    • 若您需要查看調用API介面配置該執行個體時的參數資訊,請將滑鼠游標移動至下一步儲存任務並預檢查按鈕上,然後單擊氣泡中的預覽OpenAPI參數

    • 若您無需查看或已完成查看API參數,請單擊頁面下方的下一步儲存任務並預檢查

      說明
      • 在同步作業正式啟動之前,會先進行預檢查。只有預檢查通過後,才能成功啟動同步作業。

      • 如果預檢查失敗,請單擊失敗檢查項後的查看詳情,並根據提示修複後重新進行預檢查。

      • 如果預檢查產生警告:

        • 對於不可以忽略的檢查項,請單擊失敗檢查項後的查看詳情,並根據提示修複後重新進行預檢查。

        • 對於可以忽略無需修複的檢查項,您可以依次單擊確認警示詳情確認屏蔽確定重新進行預檢查,跳過警示檢查項重新進行預檢查。如果選擇屏蔽警示檢查項,可能會導致資料不一致等問題,給業務帶來風險。

  8. 預檢查通過率顯示為100%時,單擊下一步購買

  9. 購買頁面,選擇資料同步執行個體的計費方式、鏈路規格,詳細說明請參見下表。

    類別

    參數

    說明

    資訊配置

    計費方式

    • 預付費(訂用帳戶):在建立執行個體時支付費用。適合長期需求,價格比隨用隨付更實惠,且購買時間長度越長,折扣越多。

    • 後付費(隨用隨付):按小時計費。適合短期需求,用完可立即釋放執行個體,節省費用。

    資源群組配置

    執行個體所屬的資源群組,預設為default resource group。更多資訊,請參見什麼是資源管理

    鏈路規格

    DTS為您提供了不同效能的同步規格,同步鏈路規格的不同會影響同步速率,您可以根據業務情境進行選擇。更多資訊,請參見資料同步鏈路規格說明

    訂購時間長度

    在預付費模式下,選擇訂用帳戶執行個體的時間長度和數量,包月可選擇1~9個月,包年可選擇1年、2年、3年和5年。

    說明

    該選項僅在付費類型為預付費時出現。

  10. 配置完成後,閱讀並勾選《資料轉送(隨用隨付)服務條款》

  11. 單擊購買並啟動,同步任務正式開始,您可在資料同步介面查看具體任務進度。

執行步驟

執行簡介

  1. 預檢查:在資料移轉或同步過程開始前的準備階段,用於確認所有需要的條件是否滿足。例如,網路連接、系統許可權、資料格式和完整性等。

  2. 前置模組:在資料處理流程中,前置模組通常是對資料進行預先處理。主要是指建立一些必要的觸發器來處理後續的資料。

  3. 增量資料擷取:該模組關注於僅採集自上一次採集操作後改變或新增的資料。有助於提高效率,因為它避免了處理不變的資料。

  4. 結構遷移:在資料移轉過程中,結構遷移涉及將資料從一個系統或格式轉移到另一個系統或格式,同時保持資料的結構一致性。這通常是初步遷移步驟,用於設定新環境的資料結構。大部分的遷移工作,例如表結構、序列、函數預存程序、視圖、索引都在這一步完成遷移。

  5. 全量遷移:將資料庫或資料倉儲的所有資料完整無缺地遷移到另一個系統。

  6. 結構遷移2:在初步結構遷移後進行的第二輪結構調整,用於更精細地調整和最佳化資料結構,或者解決初步遷移中發現的問題。主要會建立一些表上的外鍵。

  7. 增量寫入:在完成初步的全量遷移之後,隨著源系統中資料的更新,新增和變更的資料需要被識別並遷移到目標系統中。增量寫入正是執行這一操作的步驟。

  8. 後置模組:資料移轉或同步完成後,後置模組執行的可能是一系列尾聲工作。例如,資料清理、索引建立或效能最佳化等。

  9. 全量校正:在資料移轉後,需要進行校正以確保資料的完整性和準確性。全量校正就是對遷移後的全部資料進行校對,以確認資料是否正確無誤地複製到了新系統。

  10. 增量校正:類似於全量校正,增量校正專註於驗證只對增量資料進行的遷移。它確保自上次校正以來對資料所做的任何更改都被準確地捕獲和遷移。

執行樣本

您可以登入新版DTS同步工作清單頁面,查看執行詳情。

  1. 預檢查

    image.png

    說明

    該步驟將自動執行,您無需關注。

  2. 前置模組

    image.png

    說明

    該步驟將自動執行,您無需關注。

  3. 增量資料擷取

    image.png

    說明

    該步驟將自動執行,您無需關注。

  4. 結構遷移

    將自動遷移大部分表、索引和序列等。包括t1、empty、t2三個表都已成功遷移。

    說明

    如果在結構遷移過程中遇到失敗的任務,您可以通過結構訂正功能來手動修正遷移的SQL語句。

    image.png

  5. 全量遷移

    將選定範圍內所有表的資料進行完整遷移,您可以在資料同步頁面查看遷移過程中的資料流量和傳輸速度。

    image.png

  6. 結構遷移2

    該步驟的核心是遷移表格的外鍵約束。在資料成功遷移之後,補充外鍵是確保跨表資料保持一致性的重要操作。

    image.png

  7. 增量寫入

    實行對源庫流量的單向同步操作。在此過程中,源庫的全部流量將被訂閱轉寄,並在目標端進行相應的處理和應用。

    image.png

  8. 後置模組

    image.png

  9. 全量校正

    全量校正的過程涉及對源庫和目標庫中的資料進行比對。在當前樣本中,源庫中的t1表和目標庫中的t1表上的835266條記錄進行了對比,資料一致,因此校正是成功的。

    image.png

  10. 增量校正

    一旦前置任務全部完成,系統會自動進入增量同步處理和校正階段。在這一階段,系統將對比兩個資料庫之間的增量資料差異。

    image.png

割接上線

在遷移完成後,強烈推薦您將遷移後的目標資料庫加入到一個測試環境中,並對其進行全面的業務測試。目標資料庫的資料應與未經處理資料庫完全同步(儘管可能存在微小的延遲,這是資料回放過程中的正常現象)。根據您的業務需求,測試時間長度可能會有所不同,但通常建議至少進行一周的測試,以確保一切運行正常,之後再執行割接上線。

在割接上線之前,您應該規劃一個具體的割接時間視窗,例如10小時。在這段時間內,未經處理資料庫將停止服務,一旦目標庫完成了資料回放,您就可以更新業務中的資料庫連接字串並重啟業務系統,隨後進行必要的基本業務測試。如果測試沒有發現任何問題,則新服務便可以重新開放。

對於舊資料庫,建議保留一段時間,直到確認目標資料庫完全穩定後,舊資料庫才可以被安全地廢棄。

相關文檔

PolarDB PostgreSQL(相容Oracle)2.0版本商業化公告