日本熟妇hd丰满老熟妇,中文字幕一区二区三区在线不卡 ,亚洲成片在线观看,免费女同在线一区二区

RDS MySQL同步至AnalyticDB for PostgreSQL Serverless模式

重要

本文中含有需要您注意的重要提示信息,忽略該信息可能對您的業務造成影響,請務必仔細閱讀。

數據傳輸服務DTS(Data Transmission Service)支持將RDS MySQL數據同步至AnalyticDB PostgreSQL版Serverless模式。通過DTS提供的數據同步功能,可以輕松實現數據的流轉,將企業數據集中分析。

前提條件

支持的MySQL類型

MySQL同步至云原生數據倉庫AnalyticDB PostgreSQL版實例,支持以下源庫類型。本文以RDS MySQL實例為例介紹配置流程,其他類型的源庫配置流程與本教程類似。

  • RDS MySQL實例。
  • ECS上的自建數據庫。
  • 通過專線、VPN網關或智能網關接入的自建數據庫。
  • 通過數據庫網關接入的自建數據庫。
  • 通過云企業網CEN接入的自建數據庫。

除MySQL外,DTS還支持以PostgreSQL、SQL Server和DB2作為數據源,具體支持的數據庫請參見支持的數據庫

注意事項

說明

DTS默認同步到目標數據庫中時會取消外鍵約束,因此源庫的級聯、刪除等操作不會同步到目標數據庫。

類型

說明

源庫限制

  • 待同步的表需具備主鍵或唯一約束,且字段具有唯一性,否則可能會導致目標數據庫中出現重復數據。

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

  • Binlog日志:

    • RDS MySQL默認已開啟Binlog,您需確保參數binlog_row_image的值為full,否則預檢查階段提示報錯,且無法成功啟動數據同步任務。參數設置方法,請參見設置實例參數

      重要
      • 如源實例為自建MySQL,則需開啟Binlog,并且確保binlog_format為row且binlog_row_image為full。

      • 如源實例自建MySQL是雙主集群(兩者互為主從),為保障DTS能獲取全部的Binlog日志,則您需開啟參數log_slave_updates。具體操作請參見為自建MySQL創建賬號并設置binlog

    • DTS要求源數據庫的本地Binlog日志至少保留7天以上,否則DTS可能因無法獲取Binlog而導致任務失敗,極端情況下甚至可能會導致數據不一致或丟失。由于您所設置的Binlog日志保存時間低于DTS要求的時間進而導致的問題,不在DTS的SLA保障范圍內。如源為RDS MySQL,具體操作請參見管理本地日志(Binlog)

  • 同步期間,請勿執行修改主鍵和添加注釋的DDL操作(如ALTER TABLE table_name COMMENT='表的注釋';),否則數據同步過程中會導致執行該DDL失敗。

  • 若源庫待同步的數據中存在日期類型的數據0000-00-00 00:00:00,則可能會導致任務失敗。

    說明

    DTS將該日期數據同步到目標庫時會轉換為null。您可以臨時將源庫數據修改為0001-01-01 00:00:00,或者將目標庫對應字段設置為可空。

其他限制

  • 同步對象要求:

    • 僅支持表級同步。

    • 不支持BIT、VARBIT、GEOMETRY、ARRAY、UUID、TSQUERY、TSVECTOR、TXID_SNAPSHOT、POINT類型的數據同步。

    • 暫不支持同步前綴索引,如果源庫存在前綴索引可能導致數據同步失敗。

  • 執行數據同步前需評估源庫和目標庫的性能,同時建議業務低峰期執行數據同步。否則全量數據初始化時將占用源庫和目標庫一定的讀寫資源,可能會導致數據庫的負載上升。

  • 全量初始化會并發執行INSERT操作,導致目標數據庫的表產生碎片,因此全量初始化完成后目標實例的表空間比源實例的表空間大。

  • 如同步對象為單個或多個表(非整庫),那么在數據同步時,勿對源庫的同步對象使用pt-online-schema-change等類似工具執行在線DDL變更,否則會導致同步失敗。

    您可以使用數據管理DMS(Data Management)來執行在線DDL變更,請參見不鎖表結構變更

  • 在DTS同步期間,不允許有除DTS外的數據寫入目標庫,否則會導致源庫與目標庫數據不一致。例如,有除DTS外的數據寫入目標庫時,使用DMS執行在線DDL變更,可能引起目標庫數據丟失。

  • 目標表暫不支持AO表。

  • 若使用列映射時為非全表同步或者源與目標表結構不一致,則目標端比源端缺少的列的數據將會丟失。

特殊情況

  • 當源庫為自建MySQL時:

    • 在同步時,如果源庫進行主備切換,將會導致同步任務失敗。

    • 由于DTS的延遲時間是根據同步到目標庫最后一條數據的時間戳和當前時間戳對比得出,源庫長時間未執行DML操作可能導致延遲信息不準確。如果任務顯示的延遲時間過大,您可以在源庫執行一個DML操作來更新延遲信息。

      說明

      如果同步對象選擇為整庫,您還可以創建心跳表,心跳表每秒定期更新或者寫入數據。

    • DTS會在源庫定時執行CREATE DATABASE IF NOT EXISTS `test`命令以推進Binlog位點。

  • 當源庫為RDS MySQL時:

    不記錄事務日志的RDS MySQL實例(如RDS MySQL 5.6版本的只讀實例)不支持作為源庫。

費用說明

同步類型鏈路配置費用
庫表結構同步和全量數據同步不收費。
增量數據同步收費,詳情請參見計費概述

支持的同步架構

  • 1對1單向同步。

  • 1對多單向同步。

  • 多對1單向同步。

支持同步的SQL操作

  • DML操作:INSERT、UPDATE、DELETE。

  • DDL操作:ADD COLUMN。

    說明

    不支持CREATE TABLE操作,如果您需要將新增的表作為同步對象,則需要執行新增同步對象操作。

術語及概念對應關系

MySQL

云原生數據倉庫AnalyticDB PostgreSQL

Database

Schema

Table

Table

操作步驟

  1. 登錄新版DTS同步任務的列表頁面

    說明

    您也可以登錄DMS數據管理服務。在頂部菜單欄中,選擇集成與開發(DTS),在左側導航欄選擇數據傳輸(DTS) > 數據同步

  2. 在頁面左上角,選擇同步實例所屬地域。

  3. 單擊創建任務,配置源庫和目標庫信息。

    類別

    配置

    說明

    任務名稱

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

    源庫信息

    選擇已有的實例

    選擇已有的RDS MySQL實例,非必選項。

    數據庫類型

    選擇MySQL

    接入方式

    選擇云實例

    實例地區

    選擇源RDS MySQL實例所屬地域。

    是否跨阿里云賬號

    本教程以不跨賬號為例,選擇不跨賬號

    RDS實例ID

    選擇源RDS MySQL實例ID。

    數據庫賬號

    填入源RDS MySQL實例的數據庫賬號,需具備REPLICATION CLIENT、REPLICATION SLAVE、SHOW VIEW和SELECT權限。

    數據庫密碼

    填入該數據庫賬號對應的密碼。

    連接方式

    根據需求選擇非加密連接SSL安全連接。如果設置為SSL安全連接,您需要提前開啟RDS MySQL實例的SSL加密功能,詳情請參見設置SSL加密

    目標庫信息

    選擇已有的實例

    選擇已有的AnalyticDB PostgreSQL版Serverless模式實例,非必選項。

    數據庫類型

    選擇AnalyticDB PostgreSQL

    接入方式

    選擇云實例

    實例地區

    選擇目標AnalyticDB PostgreSQL版Serverless模式實例所屬地域。

    實例ID

    選擇目標AnalyticDB PostgreSQL版Serverless模式實例ID。

    數據庫名稱

    填入目標AnalyticDB PostgreSQL版Serverless模式實例中同步對象所屬數據庫的名稱。

    數據庫賬號

    填入目標AnalyticDB PostgreSQL版Serverless模式實例的初始賬號。

    說明

    您也可以填入具備RDS_SUPERUSER權限的賬號,創建方法請參見用戶權限管理

    數據庫密碼

    填入該數據庫賬號對應的密碼。

  4. 配置完成后,單擊頁面下方的測試連接以進行下一步配置任務對象及高級配置。

    說明
    • DTS會自動將對應地域DTS服務器的IP地址添加到RDS MySQL的安全規則中,您無需手動添加,請參見DTS服務器的IP地址段

    • DTS任務完成或釋放后,建議您手動刪除添加的DTS服務器的IP地址。

    1. 配置任務步驟及列表。

      配置

      說明

      任務步驟

      固定選中增量同步。默認情況下,您還需要同時選中庫表結構同步全量同步。預檢查完成后,DTS會將源實例中待同步對象的全量數據在目標集群中初始化,作為后續增量同步數據的基線數據。

      目標已存在表的處理模式

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

        說明

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

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

        警告

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

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

          • 全量期間,DTS會保留目標集群中的該條記錄,即源庫中的該條記錄不會同步至目標數據庫中。

          • 增量期間,DTS不會保留目標集群中的該條記錄,即源庫中的該條記錄會覆蓋至目標數據庫中。

        • 表結構不一致的情況下,可能會導致無法初始化數據、只能同步部分列的數據或同步失敗。

      實例級別選擇所需同步的DDL和DML

      按實例級別選擇同步的DDL或DML操作,支持的同步操作,請參見支持同步的SQL操作

      說明

      如需按庫或表級別選擇同步的SQL操作,請在已選擇對象中右擊同步對象,在對話框中勾選所需同步的SQL操作。

      同步對象

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

      說明

      同步對象的選擇粒度為表。

      映射名稱更改

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

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

      過濾待同步數據

      支持設置WHERE條件過濾數據,請參見設置過濾條件

      同步的SQL操作

      請右擊已選擇對象中的同步對象,在跳框中選擇所需同步的DML和DDL操作,支持的操作,請參見支持同步的SQL操作

    2. 單擊下一步高級配置

      配置

      說明

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

      選擇DTS專屬集群,不選擇默認為使用共享集群。關于DTS專屬集群的詳細信息,請參見什么是DTS專屬集群

      設置告警

      是否設置告警,當同步失敗或延遲超過閾值后,將通知告警聯系人。

      • 不設置:不設置告警。

      • 設置:設置告警,您還需要設置告警閾值和告警聯系人。

      源表DMS_ONLINE_DDL過程中是否復制臨時表到目標庫

      如源庫使用數據管理DMS(Data Management Service)執行Online DDL變更,您可以選擇是否同步Online DDL變更產生的臨時表數據。

      • :同步Online DDL變更產生的臨時表數據。

        說明

        Online DDL變更產生的臨時表數據過大,可能會導致同步任務延遲。

      • :不同步Online DDL變更產生的臨時表數據,只同步源庫的原始DDL數據。

        說明

        該方案會導致目標庫鎖表。

      源庫、目標庫無法連接后的重試時間

      在同步任務連接失敗時,DTS會立即進行持續的重試連接,默認持續重試時間為120分鐘,您也可以在取值范圍(10~1440分鐘)內自定義重試時間,建議設置30分鐘以上。如果DTS在設置的重試時間內重新連接上源庫、目標庫,同步任務將自動恢復。否則,同步任務將失敗。

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

      • 由于連接重試期間,DTS將收取任務運行費用,建議您根據業務需要自定義重試時間,或者在源和目標庫實例釋放后盡快釋放DTS實例。

      為目標對象添加引號

      選擇是否需要為目標對象名添加引號。如果選擇為,且存在下述情況,DTS在結構初始化階段和增量數據遷移階段會為目標對象添加單引號或雙引號:

      • 源庫所屬的業務環境對大小寫敏感且大小寫混用。

      • 源表名不是以字母開頭,且包含字母、數字或特殊字符以外的字符。

        說明

        特殊字符僅支持下劃線(_),井號(#)和美元符號($)。

      • 待遷移的Schema、表或列名稱是目標庫的關鍵字、保留字或非法字符。

        說明

        如果選擇添加引號,在數據同步完成后,您需使用帶引號的目標對象名進行查詢。

      配置ETL功能

      選擇是否配置ETL功能。關于ETL的更多信息,請參見什么是ETL

  5. 上述配置完成后,單擊頁面下方的下一步配置庫表字段,設置待同步的表在目標AnalyticDB PostgreSQL版中的主鍵列和分布列信息。

  6. 保存任務并進行預檢查。

    • 若您需要查看調用API接口配置該實例時的參數信息,請將鼠標光標移動至下一步保存任務并預檢查按鈕上,然后單擊氣泡中的預覽OpenAPI參數

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

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

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

    • 如果預檢查產生警告:

      • 對于不可以忽略的檢查項,請單擊失敗檢查項后的查看詳情,并根據提示修復后重新進行預檢查。

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

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

  8. 購買頁面,選擇數據同步實例的計費方式、鏈路規格,詳細說明請參見下表。

    類別

    參數

    說明

    信息配置

    計費方式

    • 預付費(包年包月):在新建實例時支付費用。適合長期需求,價格比按量付費更實惠,且購買時長越長,折扣越多。

    • 后付費(按量付費):按小時扣費。適合短期需求,用完可立即釋放實例,節省費用。

    資源組配置

    實例所屬的資源組,默認為default resource group。更多信息,請參見什么是資源管理

    鏈路規格

    DTS為您提供了不同性能的同步規格,同步鏈路規格的不同會影響同步速率,您可以根據業務場景進行選擇。更多信息,請參見數據同步鏈路規格說明

    訂購時長

    在預付費模式下,選擇包年包月實例的時長和數量,包月可選擇1~9個月,包年可選擇1年、2年、3年和5年。

    說明

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

  9. 配置完成后,閱讀并勾選《數據傳輸(按量付費)服務條款》

  10. 單擊購買并啟動,同步任務正式開始,您可在數據同步界面查看具體任務進度。

常見問題

  • 如果結構遷移步驟報錯,確認表結構一致的情況下依舊報錯,請提交工單聯系技術支持進行處理。

  • 數據同步過程中不會自動進行VACUUM,會影響后續數據寫入速度,建議您周期性對數據庫進行VACUUM。

  • 如果全量同步時出現異常,需要您清除目標表數據后重新寫入。

  • Serverless模式實例在單表大批量寫入場景的性能表現較好,但是在熱點行、多表小批量寫入的場景表現不佳。如果您的使用場景是熱點行、多表小批量寫入的場景,建議您提交工單聯系技術支持針對內核參數優化以提升性能。