本文中含有需要您注意的重要提示信息,忽略該信息可能對您的業務造成影響,請務必仔細閱讀。
數據同步功能幫助您實現數據源之間的數據實時同步,適用于數據異地多活、數據異地災備、本地數據災備、跨境數據同步、云BI及實時數據倉庫等多種業務場景。本文以RDS MySQL同步至RDS MySQL為例為您介紹在DTS專屬集群中配置數據同步任務的流程。
前提條件
已創建DTS專屬集群,創建方式,請參見創建DTS專屬集群。
已創建源和目標RDS MySQL實例,創建方式,請參見快速創建RDS MySQL實例。
目標RDS MySQL實例的存儲空間須大于源RDS MySQL實例占用的存儲空間。
源和目標庫需要和DTS專屬集群在同一個地域。
注意事項
在庫表結構同步過程中,DTS會將源數據庫中的外鍵同步到目標數據庫。
在全量同步和增量同步過程中,DTS會以Session級別暫時禁用約束檢查以及外鍵級聯操作。若任務運行時源庫存在級聯更新、刪除操作,可能會導致數據不一致。
類型 | 說明 |
源庫限制 |
|
其他限制 |
|
其他注意事項 |
|
支持的同步架構
一對一單向同步
一對多單向同步
級聯單向同步
多對一單向同步
一對一雙向同步
關于各類同步架構的介紹及注意事項,請參見數據同步拓撲介紹。
支持同步的SQL
操作類型 | SQL操作語句 |
DML | INSERT、UPDATE、DELETE |
DDL |
|
操作步驟
進入DTS專屬集群頁面。
在工作臺右側,選擇專屬集群所在地域。
說明若您登錄的是數據管理DMS控制臺,需要在集群任務右側,選擇專屬集群所在地域。
在目標專屬集群操作列,選擇 。
配置源庫信息和目標庫信息。
警告選擇源和目標實例后,建議您仔細閱讀頁面上方顯示的使用限制,否則可能會導致任務失敗或數據不一致。
類別
配置
說明
無
任務名稱
DTS會自動生成一個任務名稱,建議配置具有業務意義的名稱(無唯一性要求),便于后續識別。
源庫信息
選擇已有連接信息
您可以按實際需求,選擇是否使用已有實例。
如使用已有實例,下方數據庫信息將自動填入,您無需重復輸入。
如不使用已有實例,您需要輸入下方的數據庫信息。
數據庫類型
選擇MySQL。
接入方式
選擇云實例。
實例地區
源RDS MySQL實例所屬地域。在創建專屬集群時已指定,不支持更改。
是否跨阿里云賬號
本示例使用當前阿里云賬號下的數據庫實例,需選擇不跨賬號。
RDS實例ID
選擇源RDS MySQL實例ID。
說明源和目標RDS MySQL實例可以不同或相同,即您可以使用DTS實現兩個RDS MySQL實例間的數據同步或同一RDS MySQL實例內的數據同步。
數據庫賬號
填入源RDS MySQL實例的數據庫賬號,需具備待同步對象的讀權限。
數據庫密碼
填入該數據庫賬號對應的密碼。
連接方式
根據需求選擇非加密連接或SSL安全連接。如果設置為SSL安全連接,您需要提前開啟RDS MySQL實例的SSL加密功能,詳情請參見設置SSL加密。
目標庫信息
選擇已有連接信息
您可以按實際需求,選擇是否使用已有實例。
如使用已有實例,數據庫信息將自動填入,您無需重復輸入。
如不使用已有實例,您需要輸入下方的數據庫信息。
數據庫類型
選擇MySQL。
接入方式
選擇云實例。
實例地區
選擇目標RDS MySQL實例所屬地域。
是否跨阿里云賬號
本示例使用當前阿里云賬號下的數據庫實例,需選擇不跨賬號。
RDS實例ID
選擇目標RDS MySQL實例ID。
說明源和目標RDS MySQL實例可以不同或相同,即您可以使用DTS實現兩個RDS MySQL實例間的數據同步或同一RDS MySQL實例內的數據同步。
數據庫賬號
填入目標RDS MySQL實例的數據庫賬號,需具備目標庫的讀寫權限。
數據庫密碼
填入該數據庫賬號對應的密碼。
連接方式
根據需求選擇非加密連接或SSL安全連接。如果設置為SSL安全連接,您需要提前開啟RDS MySQL實例的SSL加密功能,詳情請參見設置SSL加密。
配置完成后,單擊頁面下方的測試連接以進行下一步。
如果源或目標數據庫是阿里云數據庫實例(例如RDS MySQL、云數據庫MongoDB版等),DTS會自動將對應地區DTS服務的IP地址添加到阿里云數據庫實例的白名單中;如果源或目標數據庫是ECS上的自建數據庫,DTS會自動將對應地區DTS服務的IP地址添到ECS的安全規則中,您還需確保自建數據庫沒有限制ECS的訪問(若數據庫是集群部署在多個ECS實例,您需要手動將DTS服務對應地區的IP地址添到其余每個ECS的安全規則中);如果源或目標數據庫是IDC自建數據庫或其他云數據庫,則需要您手動添加對應地區DTS服務的IP地址,以允許來自DTS服務器的訪問。DTS服務的IP地址,請參見DTS服務器的IP地址段。
警告DTS自動添加或您手動添加DTS服務的公網IP地址段可能會存在安全風險,一旦使用本產品代表您已理解和確認其中可能存在的安全風險,并且需要您做好基本的安全防護,包括但不限于加強賬號密碼強度防范、限制各網段開放的端口號、內部各API使用鑒權方式通信、定期檢查并限制不需要的網段,或者使用通過內網(專線/VPN網關/智能網關)的方式接入。
配置任務對象。
在對象配置頁面,配置待同步的對象。
配置
說明
同步類型
固定選中增量同步。默認情況下,您還需要同時選中庫表結構同步和全量同步。預檢查完成后,DTS會將源實例中待同步對象的全量數據在目標集群中初始化,作為后續增量同步數據的基線數據。
源庫觸發器遷移方式
請根據實際情況選擇同步觸發器的方式,若您待同步的對象不涉及觸發器,則無需配置。更多信息,請參見同步或遷移源庫中的觸發器。
說明僅當同步類型選擇了庫表結構同步時才可以配置。
開啟遷移評估
評估源庫和目標庫的結構(如索引長度、存儲過程、依賴的表等)是否滿足要求,您可以根據實際情況選擇是或者否。
說明僅當同步類型選擇了庫表結構同步時才可以配置。
若選擇是,則可能會增加預檢查時間。您可以在預檢查階段查看評估結果,評估結果不影響預檢查結果。
同步拓撲
選擇單向同步。
目標已存在表的處理模式
預檢查并報錯攔截:檢查目標數據庫中是否有同名的表。如果目標數據庫中沒有同名的表,則通過該檢查項目;如果目標數據庫中有同名的表,則在預檢查階段提示錯誤,數據同步任務不會被啟動。
說明如果目標庫中同名的表不方便刪除或重命名,您可以更改該表在目標庫中的名稱,請參見庫表列名映射。
忽略報錯并繼續執行:跳過目標數據庫中是否有同名表的檢查項。
警告選擇為忽略報錯并繼續執行,可能導致數據不一致,給業務帶來風險,例如:
表結構一致的情況下,如在目標庫遇到與源庫主鍵或唯一鍵的值相同的記錄:
全量期間,DTS會保留目標集群中的該條記錄,即源庫中的該條記錄不會同步至目標數據庫中。
增量期間,DTS不會保留目標集群中的該條記錄,即源庫中的該條記錄會覆蓋至目標數據庫中。
表結構不一致的情況下,可能會導致無法初始化數據、只能同步部分列的數據或同步失敗,請謹慎操作。
目標庫對象名稱大小寫策略
您可以配置目標實例中同步對象的庫名、表名和列名的英文大小寫策略。默認情況下選擇DTS默認策略,您也可以選擇與源庫、目標庫默認策略保持一致。更多信息,請參見目標庫對象名稱大小寫策略。
源庫對象
在源庫對象框中單擊待同步對象,然后單擊將其移動至已選擇對象框。
說明同步對象選擇的粒度為庫、表、列。若選擇的同步對象為表或列,其他對象(如視圖、觸發器、存儲過程)不會被同步至目標庫。
已選擇對象
如需更改單個同步對象在目標實例中的名稱,請右擊已選擇對象中的同步對象,設置方式,請參見庫表列名單個映射。
如需批量更改同步對象在目標實例中的名稱,請單擊已選擇對象方框右上方的批量編輯,設置方式,請參見庫表列名批量映射。
說明如需按庫或表級別選擇同步的SQL操作,請在已選擇對象中右擊待同步對象,并在彈出的對話框中選擇所需同步的SQL操作。
如需設置WHERE條件過濾數據,請在已選擇對象中右擊待同步的表,在彈出的對話框中設置過濾條件。設置方法請參見設置過濾條件。
如果使用了對象名映射功能,可能會導致依賴這個對象的其他對象同步失敗。
單擊下一步高級配置,進行高級參數配置。
配置
說明
選擇調度該任務的專屬集群
固定為當前的專屬集群,且不支持修改。
復制源表Online DDL工具執行過程的臨時表到目標庫
若源庫使用數據管理DMS(Data Management)或gh-ost執行Online DDL變更,您可以選擇是否同步Online DDL變更產生的臨時表數據。
重要DTS任務暫不支持使用pt-online-schema-change等類似工具執行Online DDL變更,否則會導致DTS任務失敗。
是:同步Online DDL變更產生的臨時表數據。
說明Online DDL變更產生的臨時表數據過大,可能會導致同步任務延遲。
否,適配DMS Online DDL:不同步Online DDL變更產生的臨時表數據,只同步源庫使用數據管理DMS(Data Management)執行的原始DDL數據。
說明該方案會導致目標庫鎖表。
否,適配gh-ost:不同步Online DDL變更產生的臨時表數據,只同步源庫使用gh-ost執行的原始DDL數據,同時您可以使用默認的或者自行配置gh-ost影子表和無用表的正則表達式。
說明該方案會導致目標庫鎖表。
是否遷移賬號
請根據實際情況選擇是否同步源庫的賬號信息。若您選擇是,您還需要選擇待同步的賬號并確認賬號權限。授權方式等信息,請參見遷移數據庫賬號。
源庫、目標庫無法連接后的重試時間
在同步任務啟動后,若源庫或目標庫連接失敗則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將占用源庫和目標庫一定的讀寫資源,可能會導致數據庫的負載上升。您可以根據實際情況,選擇是否對全量同步任務進行限速設置(設置每秒查詢源庫的速率QPS、每秒全量遷移的行數RPS和每秒全量遷移的數據量(MB)BPS),以緩解目標庫的壓力。
說明僅當同步類型選擇了全量同步時才可以配置。
是否限制增量同步速率
您也可以根據實際情況,選擇是否對增量同步任務進行限速設置(設置每秒增量同步的行數RPS和每秒增量同步的數據量(MB)BPS),以緩解目標庫的壓力。
環境標簽
您可以根據實際情況,選擇用于標識實例的環境標簽。本示例無需選擇。
是否去除正反向任務的心跳表sql
根據業務需求選擇是否在DTS實例運行時,在源庫中寫入心跳SQL信息。
是:不在源庫中寫入心跳SQL信息,DTS實例可能會顯示有延遲。
否:在源庫中寫入心跳SQL信息,可能會影響源庫的物理備份和克隆等功能。
監控告警
是否設置告警,當同步失敗或延遲超過閾值后,將通知告警聯系人。
不設置:不設置告警。
設置:設置告警,您還需要設置告警閾值和告警聯系人。更多信息,請參見在配置任務過程中配置監控告警。
單擊下一步校驗配置,進行數據校驗任務配置。
若您需要使用數據校驗功能,配置方法請參見配置數據校驗。
保存任務并進行預檢查。
若您需要查看調用API接口配置該實例時的參數信息,請將鼠標光標移動至下一步保存任務并預檢查按鈕上,然后單擊氣泡中的預覽OpenAPI參數。
若您無需查看或已完成查看API參數,請單擊頁面下方的下一步保存任務并預檢查。
說明在同步作業正式啟動之前,會先進行預檢查。只有預檢查通過后,才能成功啟動同步作業。
如果預檢查失敗,請單擊失敗檢查項后的查看詳情,并根據提示修復后重新進行預檢查。
如果預檢查產生警告:
對于不可以忽略的檢查項,請單擊失敗檢查項后的查看詳情,并根據提示修復后重新進行預檢查。
對于可以忽略無需修復的檢查項,您可以依次單擊點擊確認告警詳情、確認屏蔽、確定、重新進行預檢查,跳過告警檢查項重新進行預檢查。如果選擇屏蔽告警檢查項,可能會導致數據不一致等問題,給業務帶來風險。
預檢查通過率顯示為100%時,單擊下一步-選擇DTS實例規格。
在信息配置區域配置任務的鏈路規格,最少配置1DU,最多配置剩余可用數。
配置完成后,閱讀并勾選《數據傳輸(按量付費)服務條款》。
單擊啟動任務并單擊對話框的確定,同步任務正式開始。
您可以在集群任務列表中篩選目標任務,并查看任務的進度。