做者:沈瑀昊git
DM(TiDB Data Migration)是由 PingCAP 開發的一體化數據同步平臺,支持從 MySQL 或 MariaDB 到 TiDB 的全量數據遷移和增量數據同步。不管是從 MySQL 向 TiDB 進行平滑數據遷移仍是用 TiDB 做爲多個 MySQL 實例的數據彙總庫,均可以經過 DM 來實現。DM 在 TiDB DevCon 2019 上正式開源,通過半年多時間在大量用戶、開發者的支持和反饋下,其功能和穩定性愈來愈完善。在今天,咱們宣佈 DM 1.0 GA 正式發佈。github
<center>DM Architecture</center>優化
在進行上下游數據同步的時候,通常須要先進行全量數據複製,再進行增量數據同步。DM 同步任務支持配置多個上游 MySQL/MariaDB 實例,而且同時執行全量遷移和增量同步,能夠簡單穩定地知足用戶遷移數據的場景。blog
DM 提供了包括庫表路由(Table routing)、黑白名單(Black & white table lists)、binlog 過濾(Binlog event filter)在內豐富的數據同步規則,支持在數據同步中進行自定義配置。路由
在使用 MySQL 支撐大量數據時,常常會選擇使用分庫分表的方案。但當將數據同步到 TiDB 後,一般但願邏輯上進行合庫合表。DM 針對合庫合表的同步場景,提供了強大的分庫分表自動合併機制,可以協調上游各分片之間的 DDL 同步,保證數據同步的正確性。開發
在數據同步的過程當中,上游、下游、DM 自身的問題都有可能致使同步任務的中斷。DM 針對常見的異常同步場景進行了優化,支持自動檢測相關服務狀態並自動嘗試恢復大部分的異常同步任務,使得同步任務的運行更加穩定可靠。文檔
你們能夠參考 DM 使用文檔 來部署並體驗,參考 DM 升級指南 更新至 GA 版本。想深刻了解 DM 相關實現原理的同窗,也能夠查看 DM 源代碼 以及配套的 DM 源碼閱讀系列 文章。若是有相關的問題,歡迎在 Github 上提 issue 或者是在 AskTUG 問答社區 中討論。部署
最後再次感謝各位用戶、開發者對 DM 提供的支持和幫助。在 DM 1.0 GA 發佈以後,咱們會持續打磨優化 DM,在接下來的版本中,提供 DM 組件高可用、優化分庫分表合併機制、支持同步過程在線校驗等新特性,向更加完善的數據同步平臺方向持續演進。get