雲資料庫ClickHouse是面向線上分析處理的列式資料庫,基於大寬表的彙總分析查詢效能非常優異,比其他AnalyticDB速度快一個數量級,通過Data Transmission Service,您可以將MySQL資料庫(例如自建MySQL或RDS MySQL)同步至ClickHouse叢集,協助您輕鬆實現資料的流轉,將企業資料集中分析。本文以RDS MySQL執行個體為例,介紹從RDS MySQL同步至ClickHouse叢集的配置步驟。
注意事項
類型 | 說明 |
源庫限制 | |
其他限制 | 若源RDS MySQL的DDL語句不是標準的MySQL文法,則可能導致同步任務失敗或資料丟失。 不支援同步RENAME TABLE的操作。 雲資料庫ClickHouse的時間類型資料存在範圍限制,若RDS MySQL中的時間不在該範圍內,會導致同步到雲資料庫ClickHouse的時間不正確。範圍限制,請參見時間資訊。 分區鍵不可以選擇為可空的欄位,否則同步任務將會失敗。 待同步資料庫的數量符合雲資料庫ClickHouse的限制,即不超過256個。 待同步資料庫、表和列的名稱符合雲資料庫ClickHouse的命名規範,相關規範請參見對象命名規範限制。 在庫表結構同步階段,DTS會在目標表中添加欄位_sign和_version。若您配置同步類型時未勾選庫表結構同步,則需要手動在目標表中添加欄位。欄位資訊,請參見欄位資訊。 執行資料同步前需評估源庫和目標庫的效能,同時建議業務低峰期執行資料同步。否則全量資料初始化時將佔用源庫和目標庫一定的讀寫資源,可能會導致資料庫的負載上升。 如同步對象為單個或多個表(非整庫),那麼在資料同步時,勿對源庫的同步對象使用pt-online-schema-change等類似工具執行線上DDL變更,否則會導致同步失敗。 您可以使用Data Management(Data Management)來執行線上DDL變更,請參見不鎖表結構變更。 在DTS同步期間,不允許有除DTS外的資料寫入目標庫,否則會導致源庫與目標庫資料不一致。 若RDS MySQL執行個體已開通全密態(EncDB)功能,則不支援全量資料同步。
|
其他注意事項 | 當源庫為自建MySQL時: 在同步時,如果源庫進行主備切換,將會導致同步任務失敗。 由於DTS的延遲時間是根據同步到目標庫最後一條資料的時間戳記和目前時間戳對比得出,源庫長時間未執行DML操作可能導致延遲資訊不準確。如果任務顯示的延遲時間過大,您可以在源庫執行一個DML操作來更新延遲資訊。 說明 如果同步對象選擇為整庫,您還可以建立心跳錶,心跳錶每秒定期更新或者寫入資料。 DTS會在源庫定時執行CREATE DATABASE IF NOT EXISTS `test`命令以推進Binlog位點。
當源庫為RDS MySQL時: 不記錄交易記錄的RDS MySQL執行個體(如RDS MySQL 5.6版本的唯讀執行個體)不支援作為源庫。
|
費用說明
同步類型 | 鏈路配置費用 |
庫表結構同步和全量資料同步 | 不收費。 |
增量資料同步 | 收費,詳情請參見計費概述。 |
支援同步的SQL操作
操作類型 | SQL動作陳述式 |
DML | INSERT、UPDATE、DELETE |
DDL | CREATE TABLE TRUNCATE TABLE ALTER TABLE ADD COLUMN MODIFY COLUMN DROP TABLE、DROP COLUMN
|
資料類型映射關係
由於MySQL和ClickHouse叢集支援的資料類型不同,資料類型無法一一對應。所以DTS在進行結構初始化時,會根據目標庫支援的資料類型進行類型映射,詳情請參見結構初始化涉及的資料類型映射關係。
資料庫帳號的許可權要求
說明
若您使用的源庫帳號不是通過RDS MySQL控制台建立且授權,您需確保該帳號具備REPLICATION CLIENT、REPLICATION SLAVE、SHOW VIEW和SELECT許可權。
操作步驟
進入同步任務的列表頁面。
登入Data Management服務。
在頂部功能表列中,單擊整合與開發(DTS)。
在左側導覽列,選擇。
在同步任務右側,選擇同步執行個體所屬地區。
說明
新版DTS同步工作清單頁面,需要在頁面左上方選擇同步執行個體所屬地區。
單擊建立任務,配置源庫及目標庫資訊。
類別 | 配置 | 說明 |
無 | 任務名稱 | DTS會自動產生一個任務名稱,建議配置具有業務意義的名稱(無唯一性要求),便於後續識別。 |
源庫資訊 | 選擇已有的DMS資料庫執行個體(可選,如未建立可忽略此處選擇,直接在下方設定資料庫資訊即可) | |
資料庫類型 | 選擇MySQL。 |
接入方式 | 選擇雲執行個體。 |
執行個體地區 | 選擇源RDS MySQL執行個體所屬地區。 |
是否跨阿里雲帳號 | 本樣本為同一阿里雲帳號間的同步,選擇不跨帳號。 |
RDS執行個體ID | 選擇源RDS MySQL執行個體ID。 |
資料庫帳號 | 填入源RDS MySQL執行個體的資料庫帳號,許可權要求請參見資料庫帳號的許可權要求。 |
資料庫密碼 | 填入該資料庫帳號對應的密碼。 |
串連方式 | 根據需求選擇非加密串連或SSL安全連線。如果設定為SSL安全連線,您需要提前開啟RDS MySQL執行個體的SSL加密功能,詳情請參見設定SSL加密。 |
目標庫資訊 | 選擇已有的DMS資料庫執行個體(可選,如未建立可忽略此處選擇,直接在下方設定資料庫資訊即可) | |
資料庫類型 | 選擇ClickHouse。 |
接入方式 | 選擇雲執行個體。 |
執行個體地區 | 選擇目標ClickHouse叢集所屬地區。 |
是否跨阿里雲帳號 | 本樣本為同一阿里雲帳號間的同步,選擇不跨帳號。 |
叢集類型 | 請根據實際情況選擇ClickHouse叢集的類型。 |
叢集ID | 選擇目標ClickHouse叢集的ID。 |
資料庫帳號 | 填入目標ClickHouse叢集的資料庫帳號,許可權要求請參見資料庫帳號的許可權要求。 |
資料庫密碼 | 填入該資料庫帳號對應的密碼。 |
配置完成後,單擊頁面下方的測試連接以進行下一步。
如果源或目標資料庫是阿里雲資料庫執行個體(例如RDS MySQL、ApsaraDB for 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同步任務。更多資訊,請參見什麼是DTS專屬叢集。 |
設定警示 | 是否設定警示,當同步失敗或延遲超過閾值後,將通知警示連絡人。 |
源庫、目標庫無法串連後的重試時間 | 在同步任務啟動後,若源庫或目標庫串連失敗則DTS會報錯,並會立即進行持續的重試串連,預設持續重試時間為720分鐘,您也可以在取值範圍(10~1440分鐘)內自訂重試時間,建議設定30分鐘以上。如果DTS在設定的重試時間內重新串連上源庫、目標庫,同步任務將自動回復。否則,同步任務將會失敗。 |
源庫、目標庫出現其他問題後的重試時間 | 在同步任務啟動後,若源庫或目標庫出現非串連性的其他問題(如DDL或DML執行異常),則DTS會報錯並會立即進行持續的重試操作,預設持續重試時間為10分鐘,您也可以在取值範圍(1~1440分鐘)內自訂重試時間,建議設定10分鐘以上。如果DTS在設定的重試時間內相關操作執行成功,同步任務將自動回復。否則,同步任務將會失敗。 重要 源庫、目標庫出現其他問題後的重試時間的值需要小於源庫、目標庫無法串連後的重試時間的值。 |
是否限制全量遷移速率 | 在全量同步階段,DTS將佔用源庫和目標庫一定的讀寫資源,可能會導致資料庫的負載上升。您可以根據實際情況,選擇是否對全量同步任務進行限速設定(設定每秒查詢源庫的速率QPS、每秒全量遷移的行數RPS和每秒全量遷移的數據量(MB)BPS),以緩解目標庫的壓力。 |
是否限制增量同步處理速率 | 您也可以根據實際情況,選擇是否對增量同步處理任務進行限速設定(設定每秒增量同步處理的行數RPS和每秒增量同步處理的數據量(MB)BPS),以緩解目標庫的壓力。 |
環境標籤 | 您可以根據實際情況,選擇用於標識執行個體的環境標籤。本樣本無需選擇。 |
配置ETL功能 | 選擇是否配置ETL功能。關於ETL的更多資訊,請參見什麼是ETL。 |
是否去除正反向任務的心跳錶sql | 根據業務需求選擇是否在DTS執行個體運行時,在源庫中寫入心跳SQL資訊。 |
單擊下一步配置庫表欄位,配置待同步表在ClickHouse中的類型、主鍵列、排序鍵、分布鍵和分區鍵資訊。
說明
DTS預設配置了一組資料,您可以將定義狀態選擇為全部後進行修改。
主鍵列和排序鍵可以是按鍵組合,即您可以在對應的下拉框中選擇多個欄位作為主鍵列或排序鍵,且需要從主鍵列中選擇1個或者多個列作分區鍵;分布鍵只能選擇一個欄位。更多關於主鍵列、排序鍵、分區鍵的資訊,請參見CREATE TABLE。
分區鍵可以不設定,但不可以選擇為可空的欄位,否則同步任務將會失敗。
儲存任務並進行預檢查。
預檢查通過率顯示為100%時,單擊下一步購買。
在購買頁面,選擇資料同步執行個體的計費方式、鏈路規格,詳細說明請參見下表。
類別 | 參數 | 說明 |
資訊配置 | 計費方式 | |
資源群組配置 | 執行個體所屬的資源群組,預設為default resource group。更多資訊,請參見什麼是資源管理。 |
鏈路規格 | DTS為您提供了不同效能的同步規格,同步鏈路規格的不同會影響同步速率,您可以根據業務情境進行選擇。更多資訊,請參見資料同步鏈路規格說明。 |
訂購時間長度 | 在預付費模式下,選擇訂用帳戶執行個體的時間長度和數量,包月可選擇1~9個月,包年可選擇1年、2年、3年和5年。 |
配置完成後,閱讀並勾選《資料轉送(隨用隨付)服務條款》。
單擊購買並啟動,同步任務正式開始,您可在資料同步介面查看具體任務進度。
附錄
時間資訊
資料類型 | 最小值 | 最大值 |
Date | 1970-01-01 00:00:00 | 2149-06-06 00:00:00 |
Date32 | 1925-01-01 00:00:00 | 2283-11-11 00:00:00 |
DateTime | 1970-01-01 08:00:00 | 2106-02-07 14:28:15 |
DateTime64 | 1925-01-01 08:00:00 | 2283-11-12 07:59:59 |
欄位資訊
說明
若您需要尋找資料,可以使用select * from table_name final where _sign>0;
語句。其中,where條件(_sign>0)可以將刪除的資料過濾,表名後的final可以將相同排序鍵的資料過濾。
名稱 | 資料類型 | 預設值 | 說明 |
_sign | Int8 | 1 | DML操作的類型。 INSERT:記錄為1。 UPDATE:記錄為1。 DELETE:記錄為-1。
|
_version | UInt64 | 1 | 資料寫入ClickHouse的時間戳記。 |