ShardingSphere 異構遷移最佳實踐:將3.5億量級的顧客系統 RTO 減少60倍

来源:https://www.cnblogs.com/sphereex/archive/2022/06/13/16371022.html
-Advertisement-
Play Games

Apache ShardingSphere 助力噹噹 3.5 億用戶量級顧客系統重構,由 PHP+SQL Server 技術棧無縫轉型為 Java+ShardingSphere+MySQL,性能、可用性及維護性均得到顯著提升,是 ShardingSphere 異構遷移最佳實踐。 ...


Apache ShardingSphere 助力噹噹 3.5 億用戶量級顧客系統重構,由 PHP+SQL Server 技術棧無縫轉型為 Java+ShardingSphere+MySQL,性能、可用性及維護性均得到顯著提升,是 ShardingSphere 異構遷移最佳實踐。

1  顧客系統背景

噹噹顧客系統主要負責賬戶的註冊、登錄、隱私數據維護等功能,歷史技術棧為 PHP+SQL Server,是標準的集中式架構,如下圖。

重構項目啟動前,顧客系統的數個業務模塊存在多個棘手的業務問題和技術挑戰,如邏輯分散、吞吐量低及運維成本高等問題。為改善顧客的購物體驗,噹噹技術團隊決定對業務邏輯和底層數據架構進行優化,實現顧客系統多場景下的可用性、擴展性及綜合提升等多個目標。在重構過程也實現了眾多技術創新,如跨數據源雙寫、讀寫分離、智能網關及灰度發佈等技術。

從需求設計、分庫分表規劃、邏輯優化、壓測再到完全上線等多個環節,噹噹技術團隊用半年的時間完成了基於 3.5 億+用戶的系統重構。

使用 Java 語言重構十餘個模塊,通過 ShardingSphere+ MySQL 構建分散式資料庫解決方案,順利完成異構資料庫線上遷移,案例亮點如下。

  • 使用 Java 語言重構 PHP 業務代碼;

  • 使用 ShardingSphere+MySQL 替換 SQL Server;

  • 線上完成 3.5 億用戶數據完整遷移;

  • 通過數據雙寫方案完成無縫上線。

2  痛點&挑戰

業務痛點

在業務層面,顧客系統部分模塊的註冊和登錄邏輯分散在各端,維護成本較高,且當時的技術架構對於性能的提升和高可用性存在著很大的局限性。

  • 不易維護:多平臺註冊和登錄邏輯較為分散,業務維護複雜;

  • 性能受限:PHP+SQL Server 集中式技術架構,吞吐量不足;

  • 可用性&安全性差

  • SQL Server 主備狀態變化後,訂閱庫會失效,重新配置需要視窗時間;

  • SQL Server 運行在 Windows Server 上,病毒影響導致安全性差,且打補丁後升級啟動時間長(>30min)。

挑戰

  • 數據完整性

顧客系統擁有 3.5 億+ 用戶數據,在數據遷移過程中,需保證數據從 SQL Server 遷移到 MySQL 後的一致性及完整性;

  • API 透明

API 對調用方保持透明,確保調用方無改動,最小化變更界面;

  • 無縫切換

需要滿足業務系統無縫切換,切換過程對業務無影響;

  • 時間緊迫

“618”和“11.11”促銷活動前後會封網,因此需在兩大促活動間、有限視窗的時間內完成切換,並緊接著面對“11.11”的驗證。

3  解決方案

整體規劃

為了改善顧客系統的可維護性、可用性及性能,研發團隊重新梳理顧客系統的架構。

在應用層,統一各端的功能邏輯,提升業務可維護性。在資料庫層,將集中式架構調整為分散式資料庫架構,提升性能及可用性,即 ShardingSphere+MySQL 構建的開源分散式解決方案。

  • 應用層:隨噹噹整體技術棧的變遷,業務開發語言由 PHP 轉為 Java;

  • 中間件:使用成熟的開源資料庫中間件 ShardingSphere 實現分庫分表;

  • 資料庫:使用多套 MySQL 集群代替 SQL Server 資料庫。

在整體架構設計上,引入了分散式主鍵生成策略、分片管理、數據遷移校驗以及灰度發佈等多個方案。

分散式主鍵生成策略

資料庫架構由集中式轉型為基於中間件的分散式架構,分散式主鍵生成策略是首先需要考慮解決問題。在系統重構中,選擇建立兩台以上的資料庫 ID 生成伺服器,每台伺服器都有一張記錄各表當前 ID 的 Sequence 表,Sequence 中 ID 增長的步長是伺服器的數量。起始值依次錯開,這樣相當於把 ID 的生成散列到了每台伺服器節點上。

分片(ShardingSphere)

在顧客系統重構中,通過 Apache ShardingSphere 完成資料庫 Sharding,同時也啟用了讀寫分離功能。

由於顧客系統在高併發、低延時的要求,接入端選擇了 ShardingSphere-JDBC,它定位為輕量級 Java 框架,在 Java 的 JDBC 層提供的額外服務。它使用客戶端直連資料庫,以 jar 包形式提供服務,無需額外部署和依賴,可理解為增強版的 JDBC 驅動,完全相容 JDBC 和各種 ORM 框架。

  • Sharding

ShardingSphere 支持非常全面的分片演算法,包括取模、哈希、範圍、時間及自定義等演算法,顧客系採用取模分片演算法對大表進行拆分。

  • 讀寫分離

除了 Sharding,同時還啟用 ShardingSphere 讀寫分離功能,充分利用 MHA 集群資源,提升系統吞吐能力。

雙寫&數據同步

數據同步貫穿了整個重構項目,數據遷移的完整性及數據一致性是重構的關鍵。

該案例基於 Elastic-Job 同步歷史數據,以周期的方式將 SQL Server 的歷史數據同步到 MySQL 中。

關於資料庫切換方面,在切換過程中會採用備份方案,進行資料庫的雙寫,保證切換前後的數據一致性,過程如下。

第 1 步:實現雙寫機制

斷掉鏈路 1,打通鏈路 2、3、4,打通鏈路 9、10。

第 2 步:切換登錄服務

斷掉鏈路 9,10,打通鏈路 7,斷掉鏈路 5。

第 3 步:切換讀服務

打通鏈路 8,斷掉鏈路 6。

第 4 步:取消雙寫機制

斷掉鏈路 2,完成切換。

在數據校驗方面,通過業務側和資料庫側兩個方面進行驗證,均周期性進行檢查,在不同時間段採用不同的頻率,抽樣或全量檢查數據的完整性,在資料庫側也會進行 COUNT/SUM 的驗證。

顧客系統重構使用了基於 apollo 的灰度發佈方式,在新登錄方式的處理上,通過配置項逐步放開、小範圍陸續割接,確保上線成功率。重構後的系統架構如下圖。

4  用戶收益

經過重構,噹噹顧客系統響應速度明顯提升,同時也降低了日常運維成本,ShardingSphere 提供的分散式解決方案功不可沒。該方案適用於各種高流量的互聯網平臺服務,也適用於電商平臺以及其他以數據處理為主的系統。

  • 性能提升,響應速度提升 20% 以上;

  • 可用性增強,ShardingSphere+MySQL 的方案實現 RTO<30s;

  • 易於維護,業務邏輯以及資料庫的可維護性明顯提升;

  • 無縫遷移,6 個月內線上完成各模塊割接,視窗時間為零。

5  總結

在“ShardingSphere 助力噹噹 WMS:訂單效率提升 30%、節約成本上千萬”案例之後,這是第二篇 ShardingSphere 在噹噹的實踐案例。

Apache ShardingSphere 為業務系統提供了強力的支撐。簡單與極致,是 ShardingSphere 突出的兩個特性,讓業務邏輯更簡單,讓性能更極致。

Apache ShardingSphere 社區已在開源領域耕耘了 7 年的時間。長久的堅持,使社區愈加成熟,已呈開放和多元化的勢態。我們誠心歡迎有開源情懷和編碼熱情的朋友一起參與社區共建,也歡迎您提供優質案例內容分享給社區的朋友們。

如果大家對 Apache ShardingSphere 有任何疑問或建議,歡迎在 GitHub Issue 列表提出,或可前往中文社區交流討論。

GitHub Issue:https://github.com/apache/shardingsphere/issues

貢獻指南:https://shardingsphere.apache.org/community/cn/contribute/

中文社區:https://community.sphere-ex.com/


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文是clickhouse專欄第五篇,更多內容請關註本號歷史文章! 一、數據類型表 clickhouse內置了很多的column數據類型,可以通過查詢system.data_type_families這張表獲取版本的所有支持的數據類型。下文中第一列是欄位類型,第二列表示該類型的欄位類型是否區分大小寫 ...
  • #region 輸入數字判斷是否是數字 #region 方法實現 /*不管是實參或形參,都在類型中開闢了空間的; 方法的功能一定要單一; 如GetMax(int n1,int n2); 方法中最忌諱的就是提示用戶輸入的字眼。 ///PS:最新版的沒有namespace這些,目前我想到的調用方法和類就 ...
  • #region 調用 /* 我們在main函數中調用Test()函數,我們管main函數稱為調用者, Test函數稱為被調用者. 如果被調用者想要得到調用者的值: 1) 傳遞參數; 2) 使用靜態欄位來模擬全局變數; 如果調用者想要得到被調用者的值: 1) 返回值; */ #endregion na ...
  • #region 複習 /* 常量:一旦賦值,不能被重新賦值; 枚舉:規範開發; 結構:為了一次性聲明多個不同類型的變數(實際為欄位); 數組:為了一次性聲明多個相同類型的變數 通過下標或索引訪問數組中元素 數組的取值和賦值 冒泡排序:兩個for迴圈 Array.Sort(nums);Array.Re ...
  • 鏡像下載、功能變數名稱解析、時間同步請點擊 阿裡雲開源鏡像站 1.先查看本機的系統信息 [root@h0436 h0436 zlong]# cat /etc/redhat-release 2.進入yum.repos.d [root@h0436 zlong]# cd /etc/yum.repos.d 3.查看 ...
  • 鏡像下載、功能變數名稱解析、時間同步請點擊 阿裡雲開源鏡像站 ifconfig 命令可以用於查看、配置、啟用或禁用指定的網路介面,還可以用來配置網卡的IP地址、掩碼、廣播地址、網關等,功能很豐富 功能雖然豐富,但是如果你沒有安裝呢? 嘿嘿嘿 如果沒有安裝ifconfig管理命令的話,直接運行ifconfig ...
  • 好消息!6月13日,騰訊雲資料庫三篇論文再次入選資料庫行業頂會SIGMOD,被SIGMOD 2022 Research Full Paper(研究類長文)收錄。 本次被收錄的研究成果中,新型數據結構設計、AI智能調參優化等均屬於業界首次提出。騰訊雲資料庫多次入選SIGMOD,表明騰訊雲資料庫在存儲、 ...
  • 本文將會和大家一起學習 SQL 的搜索條件中不可或缺的工具——謂詞(predicate)。SQL 謂詞就是返回值為 TRUE、FALSE 或 UNKNOWN 的表達式。 謂詞用於 WHERE 子句 和 HAVING 子句 的搜索條件中,還用於 FROM 子句的聯接條件以及需要布爾值的其他構造中。 本 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...