通過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(成都)、中國(香港)、日本(東京)、新加坡、印尼(雅加達)、美國(矽谷)、美國(維吉尼亞)。
影響
遷移評估不會對業務造成影響。
建立遷移評估任務
登入PolarDB控制台。
在左上方,選擇叢集所在地區。
建立遷移評估任務。PolarDB提供了兩種建立遷移評估任務的入口:
從叢集列表頁建立:在叢集列表頁左上方單擊遷移/升級評估按鈕。

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

在彈出的遷移/升級評估對話方塊,填寫遷移評估任務的相關參數,然後單擊下一步。
參數名稱
參數說明
建立方式
選擇從PolarDB升級。
源PolarDB版本
選擇Oracle 1.0。
源PolarDB執行個體
選擇要遷移的源Oracle 1.0叢集。
目標資料庫引擎
選擇Oracle 2.0。
資料庫名稱
選擇要遷移的來源資料庫。
在遷移/升級評估對話方塊,您可以查看關於叢集相容性的整體描述和詳細資料。
查看整體描述。

查看詳細資料。
說明您需要重點關注相容性評估結果中的不相容對象。
對於Oracle資料庫原生對象,可以忽略。
對於業務SQL中涉及的不相容對象,需要進行改造適配。如果業務側無法改造,您可以聯絡我們,研發工程師將協助您處理。
管理遷移評估任務
對於已經建立的評估任務,您可以前往遷移/評估頁面查看評估詳情。
建立的遷移評估任務有效期間為7天,到期後將自動刪除。若您的遷移評估任務已到期,您可重新建立新的評估任務。
前提條件
已建立源和目標PolarDB PostgreSQL版(相容Oracle)資料庫叢集,詳情請參見建立PolarDB PostgreSQL版(相容Oracle)叢集。
已將源和目標PolarDB PostgreSQL版(相容Oracle)叢集的wal_level參數值設定為logical。設定方式,請參見設定叢集參數。
目標資料庫的儲存空間,需大於來源資料庫已使用的儲存空間。
注意事項
在庫表結構同步過程中,DTS會將來源資料庫中的外鍵同步到目標資料庫。
在全量同步和增量同步處理過程中,DTS會以Session層級暫時禁用約束檢查以及外鍵級聯操作。若任務運行時源庫存在串聯更新、刪除操作,可能會導致資料不一致。
類型 | 說明 |
源庫限制(PolarDB 1.0) |
|
其他限制 |
|
費用說明
同步類型 | 鏈路配置費用 |
庫表結構同步和全量資料同步 | 不收費。 |
增量資料同步 | 收費,詳情請參見計費概述。 |
遷移類型說明
遷移類型 | 說明 |
結構遷移 | DTS將遷移對象的結構定義遷移到目標庫。目前DTS支援的對象包括:表、視圖、同義字、觸發器、預存程序、儲存函數、包、自訂類型。 說明 暫不相容觸發器。建議您刪除源庫的觸發器,以避免因觸發器而導致資料不一致的問題。詳情請參見源庫存在觸發器時如何配置同步或遷移作業。 |
全量資料移轉 | DTS會將源庫中遷移對象的存量資料,全部遷移至目標庫。 說明 在結構遷移和全量資料移轉完成之前,請勿對遷移對象執行DDL操作,否則可能導致遷移失敗。 |
增量資料移轉 | DTS在全量資料移轉的基礎上輪詢並捕獲源庫產生的WAL日誌,將源庫的累加式更新資料移轉到目標庫中。 通過增量資料移轉可以實現在應用不停服的情況下,平滑地完成資料移轉。 |
支援同步的SQL操作
操作類型 | SQL動作陳述式 |
DML | INSERT、UPDATE、DELETE |
DDL | 重要
來源資料庫帳號需為高許可權帳號時,同步任務支援如下DDL操作:
重要
|
資料庫帳號的許可權要求
資料庫 | 許可權要求 |
源PolarDB PostgreSQL版(相容Oracle)叢集 | 高許可權帳號。 |
目標PolarDB PostgreSQL版(相容Oracle)叢集 | 資料庫Owner許可權。 重要 資料庫Owner在建立資料庫時已指定。資料庫帳號建立及授權方法,請參見建立資料庫帳號。 |
配置步驟
進入目標地區的遷移工作清單頁面(二選一)。
通過DTS控制台進入
在左側導覽列,單擊資料移轉。
在頁面左上方,選擇遷移執行個體所屬地區。
通過DMS控制台進入
說明實際操作可能會因DMS的模式和布局不同,而有所差異。更多資訊。請參見極簡模式控制台和自訂DMS介面布局與樣式。
在頂部功能表列中,選擇。
在遷移任務右側,選擇遷移執行個體所屬地區。
單擊建立任務,配置源庫及目標庫資訊。
說明資料類型都選擇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)叢集的高許可權資料庫帳號,帳號建立及授權方式,請參見建立資料庫帳號。
資料庫密碼
填入該資料庫帳號對應的密碼。
配置完成後,單擊頁面下方的測試連接以進行下一步。
DTS任務會自動將對應地區DTS服務的IP地址添加到阿里雲資料庫執行個體的白名單中。
警告DTS自動添加或您手動添加DTS服務的公網IP位址區段可能會存在安全風險,一旦使用本產品代表您已理解和確認其中可能存在的安全風險,並且需要您做好基本的安全防護,包括但不限於加強帳號密碼強度防範、限制各網段開放的連接埠號碼、內部各API使用鑒權方式通訊、定期檢查並限制不需要的網段,或者使用通過內網(專線/VPN網關/智能網關)的方式接入。
配置任務對象及進階配置。
說明源庫對象會列出所有的命名空間,根據需要選擇自己遷移的命名空間即可。
配置
說明
同步類型
固定選中增量同步處理。預設情況下,您還需要同時選中庫表結構同步和全量同步。預檢查完成後,DTS會將源執行個體中待同步對象的全量資料在目的地組群中初始化,作為後續增量同步處理資料的基準資料。
說明同步類型需要全選。
同步拓撲
單向拓撲:只建立源庫到目標庫的單向同步鏈路,包括存量資料及增量同步處理鏈路。
雙向同步:建立源庫到目標庫的雙向同步鏈路,同時進行源庫到目標庫的增量同步處理,以及目標庫到源庫的反向迴流。
說明反向迴流只支援資料同步,不支援DDL操作。
目標已存在表的處理模式
預檢查並報錯攔截:檢查目標資料庫中是否有同名的表。如果目標資料庫中沒有同名的表,則通過該檢查專案;如果目標資料庫中有同名的表,則在預檢查階段提示錯誤,資料同步任務不會被啟動。
說明如果目標庫中同名的表不方便刪除或重新命名,您可以更改該表在目標庫中的名稱,請參見庫表列名映射。
忽略報錯並繼續執行:跳過目標資料庫中是否有同名表的檢查項。
警告選擇為忽略報錯並繼續執行,可能導致資料不一致,給業務帶來風險,例如:
結構一致的情況下,如在目標庫遇到與源庫主鍵或唯一鍵的值相同的記錄:
全量期間,DTS會保留目的地組群中的該條記錄,即源庫中的該條記錄不會同步至目標資料庫中。
增量期間,DTS不會保留目的地組群中的該條記錄,即源庫中的該條記錄會覆蓋至目標資料庫中。
表結構不一致的情況下,可能會導致無法初始化資料、只能同步部分列的資料或同步失敗,請謹慎操作。
目標庫對象名稱大小寫策略
您可以配置目標執行個體中同步對象的庫名、表名和列名的英文大小寫策略。預設情況下選擇DTS預設策略,您也可以選擇與源庫、目標庫預設策略保持一致。更多資訊,請參見目標庫對象名稱大小寫策略。
源庫對象
在源庫對象框中單擊待同步對象,然後單擊
將其移動至已選擇對象框。說明同步對象選擇的粒度為庫、表、列。若選擇的同步對象為表或列,其他對象(如視圖、觸發器、預存程序)不會被同步至目標庫。
已選擇對象
如需更改單個同步對象在目標執行個體中的名稱,請右擊已選擇對象中的同步對象,設定方式,請參見庫表列名映射。
如需批量更改同步對象在目標執行個體中的名稱,請單擊已選擇對象方框右上方的大量編輯,設定方式,請參見庫表列名映射。
說明如需按庫或表層級選擇同步的SQL操作,請在已選擇對象中右擊待同步對象,並在彈出的對話方塊中選擇所需同步的SQL操作。支援的操作請參見支援同步的SQL操作。
如需設定WHERE條件過濾資料,請在已選擇對象中右擊待同步的表,在彈出的對話方塊中設定過濾條件。設定方法請參見設定過濾條件。
單擊下一步進階配置,進行進階配置。
配置
說明
選擇調度該任務的專屬叢集
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。
是:配置ETL功能,並在文字框中填寫資料處理語句,詳情請參見在DTS遷移或同步任務中配置ETL。
否:不配置ETL功能。
監控警示
是否設定警示,當同步失敗或延遲超過閾值後,將通知警示連絡人。
不設定:不設定警示。
設定:設定警示,您還需要設定警示閾值和警示連絡人。更多資訊,請參見配置監控警示。
單擊下一步資料校正,進行資料校正配置
配置
說明
資料校正方式
全量校正:對全部的資料進行校正。若您勾選了全量校正,您需要配置校正參數和校正對象,更多資訊,請參見在DTS同步或遷移執行個體中配置資料校正。
增量校正:固定選中,只校正資料轉送中增量部分的資料。
結構校正:固定選中,對需要校正的對象進行結構校正。
儲存任務並進行預檢查。
若您需要查看調用API介面配置該執行個體時的參數資訊,請將滑鼠游標移動至下一步儲存任務並預檢查按鈕上,然後單擊氣泡中的預覽OpenAPI參數。
若您無需查看或已完成查看API參數,請單擊頁面下方的下一步儲存任務並預檢查。
說明在同步作業正式啟動之前,會先進行預檢查。只有預檢查通過後,才能成功啟動同步作業。
如果預檢查失敗,請單擊失敗檢查項後的查看詳情,並根據提示修複後重新進行預檢查。
如果預檢查產生警告:
對於不可以忽略的檢查項,請單擊失敗檢查項後的查看詳情,並根據提示修複後重新進行預檢查。
對於可以忽略無需修複的檢查項,您可以依次單擊確認警示詳情、確認屏蔽、確定、重新進行預檢查,跳過警示檢查項重新進行預檢查。如果選擇屏蔽警示檢查項,可能會導致資料不一致等問題,給業務帶來風險。
預檢查通過率顯示為100%時,單擊下一步購買。
在購買頁面,選擇資料同步執行個體的計費方式、鏈路規格,詳細說明請參見下表。
類別
參數
說明
資訊配置
計費方式
預付費(訂用帳戶):在建立執行個體時支付費用。適合長期需求,價格比隨用隨付更實惠,且購買時間長度越長,折扣越多。
後付費(隨用隨付):按小時計費。適合短期需求,用完可立即釋放執行個體,節省費用。
資源群組配置
執行個體所屬的資源群組,預設為default resource group。更多資訊,請參見什麼是資源管理。
鏈路規格
DTS為您提供了不同效能的同步規格,同步鏈路規格的不同會影響同步速率,您可以根據業務情境進行選擇。更多資訊,請參見資料同步鏈路規格說明。
訂購時間長度
在預付費模式下,選擇訂用帳戶執行個體的時間長度和數量,包月可選擇1~9個月,包年可選擇1年、2年、3年和5年。
說明該選項僅在付費類型為預付費時出現。
配置完成後,閱讀並勾選《資料轉送(隨用隨付)服務條款》。
單擊購買並啟動,同步任務正式開始,您可在資料同步介面查看具體任務進度。
執行步驟
執行簡介
預檢查:在資料移轉或同步過程開始前的準備階段,用於確認所有需要的條件是否滿足。例如,網路連接、系統許可權、資料格式和完整性等。
前置模組:在資料處理流程中,前置模組通常是對資料進行預先處理。主要是指建立一些必要的觸發器來處理後續的資料。
增量資料擷取:該模組關注於僅採集自上一次採集操作後改變或新增的資料。有助於提高效率,因為它避免了處理不變的資料。
結構遷移:在資料移轉過程中,結構遷移涉及將資料從一個系統或格式轉移到另一個系統或格式,同時保持資料的結構一致性。這通常是初步遷移步驟,用於設定新環境的資料結構。大部分的遷移工作,例如表結構、序列、函數預存程序、視圖、索引都在這一步完成遷移。
全量遷移:將資料庫或資料倉儲的所有資料完整無缺地遷移到另一個系統。
結構遷移2:在初步結構遷移後進行的第二輪結構調整,用於更精細地調整和最佳化資料結構,或者解決初步遷移中發現的問題。主要會建立一些表上的外鍵。
增量寫入:在完成初步的全量遷移之後,隨著源系統中資料的更新,新增和變更的資料需要被識別並遷移到目標系統中。增量寫入正是執行這一操作的步驟。
後置模組:資料移轉或同步完成後,後置模組執行的可能是一系列尾聲工作。例如,資料清理、索引建立或效能最佳化等。
全量校正:在資料移轉後,需要進行校正以確保資料的完整性和準確性。全量校正就是對遷移後的全部資料進行校對,以確認資料是否正確無誤地複製到了新系統。
增量校正:類似於全量校正,增量校正專註於驗證只對增量資料進行的遷移。它確保自上次校正以來對資料所做的任何更改都被準確地捕獲和遷移。
執行樣本
您可以登入新版DTS同步工作清單頁面,查看執行詳情。
預檢查
說明該步驟將自動執行,您無需關注。
前置模組
說明該步驟將自動執行,您無需關注。
增量資料擷取
說明該步驟將自動執行,您無需關注。
結構遷移
將自動遷移大部分表、索引和序列等。包括t1、empty、t2三個表都已成功遷移。
說明如果在結構遷移過程中遇到失敗的任務,您可以通過結構訂正功能來手動修正遷移的SQL語句。

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

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

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

後置模組

全量校正
全量校正的過程涉及對源庫和目標庫中的資料進行比對。在當前樣本中,源庫中的
t1表和目標庫中的t1表上的835266條記錄進行了對比,資料一致,因此校正是成功的。
增量校正
一旦前置任務全部完成,系統會自動進入增量同步處理和校正階段。在這一階段,系統將對比兩個資料庫之間的增量資料差異。

割接上線
在遷移完成後,強烈推薦您將遷移後的目標資料庫加入到一個測試環境中,並對其進行全面的業務測試。目標資料庫的資料應與未經處理資料庫完全同步(儘管可能存在微小的延遲,這是資料回放過程中的正常現象)。根據您的業務需求,測試時間長度可能會有所不同,但通常建議至少進行一周的測試,以確保一切運行正常,之後再執行割接上線。
在割接上線之前,您應該規劃一個具體的割接時間視窗,例如10小時。在這段時間內,未經處理資料庫將停止服務,一旦目標庫完成了資料回放,您就可以更新業務中的資料庫連接字串並重啟業務系統,隨後進行必要的基本業務測試。如果測試沒有發現任何問題,則新服務便可以重新開放。
對於舊資料庫,建議保留一段時間,直到確認目標資料庫完全穩定後,舊資料庫才可以被安全地廢棄。
