資料庫分庫分表之後,你是如何解決事務問題?

来源:https://www.cnblogs.com/lingfeng23/archive/2020/07/04/13235368.html
-Advertisement-
Play Games

我們需要接受失望,因為它是有限的;我們不會失去希望,因為它是無窮的。 一、概述 隨著時間和業務的發展,資料庫中表的數據量會越來越大,相應地,數據操作,增刪改查的開銷也會越來越大。因此,把其中一些大表進行拆分到多個資料庫中的多張表中。 本篇文章是基於非事務消息的非同步確保的方式來完成分庫分表中的事務問題 ...


我們需要接受失望,因為它是有限的;我們不會失去希望,因為它是無窮的。
一、概述

隨著時間和業務的發展,資料庫中表的數據量會越來越大,相應地,數據操作,增刪改查的開銷也會越來越大。因此,把其中一些大表進行拆分到多個資料庫中的多張表中。
本篇文章是基於非事務消息的非同步確保的方式來完成分庫分表中的事務問題。

二、需要解決問題

2.1 原有事務

由於分庫分表之後,新表在另外一個資料庫中,如何保證主庫和分庫的事務性是必須要解決的問題。

解決辦法:通過在主庫中創建一個流水錶,把操作資料庫的邏輯映射為一條流水記錄。當整個大事務執行完畢後(流水被插入到流水錶),然後通過其他方式來執行這段流水,保證最終一致性。
file

2.2 流水

所謂流水,可以理解為一條事務消息

上面通過在資料庫中創建一張流水錶,使用一條流水記錄代表一個業務處理邏輯,因此,一個流水一定是能最終正確執行的.因此,當把一段業務代碼提取流水中必須要考慮到:

  • 流水延遲處理性。流水不是實時處理的,而是用過流水執行器來非同步執行的。因此,如果在原有邏輯中,需要特別註意後續流程對該流水是不是有實時依賴性(例如後續業務邏輯中會使用流水結果來做一些計算等)。

  • 流水處理無序性。保證即使後生成的流水先執行,也不能出現問題。

  • 流水最終成功性。對每條插入的流水,該條流水一定要保證能執行成功

因此,提取流水的時候:

  • 流水處理越簡單越好

  • 流失處理依賴越少越好

  • 提取的流水在該業務邏輯中無實時性依賴
    file

2.4 流水處理完成

因為流水錶是放在原資料庫中,而流水處理完成後是操作分庫,如果分庫操作完成去更新老表流水消息,那麼又是誇庫事務,如何保證流水狀態的更新和分庫也是在一個事務的?

解決辦法是:在分庫中創建一個流水錶,當流失處理完成以後,不是去更新老表狀態,而是插入分庫流水錶中、

這樣做的好處:

  • 一般會對流水做唯一索引,那麼如果流水重覆多次執行的時候,插入分庫流水錶的時候肯定由於唯一索引檢測不通過,整個事務就會回滾(當然也可以在處理流水事前應該再做一下冪等性判斷)

  • 這樣通過判斷主庫流水是否在分庫中就能判斷一條流水是否執行完畢
    file
    三、流水處理器基本框架


流水處理器其實不包含任何業務相關的處理邏輯,核心功能就是:

  • 通知業務接入方何時處理什麼樣的流水

  • 檢驗流水執行的成功

註:流水執行器並不知道該流水錶示什麼邏輯,具體需要業務系統去識別後去執行相對應業務邏輯。
file

3.1 流水執行任務

流水處理調度任務就是通過掃描待處理的流水,然後通知業務系統該執行哪一條流水。

示意圖如下:
file

3.2 流水校驗任務

流水校驗任務就是要比較主庫和分庫中的流水記錄,對執行未成功的流水通知業務系統進行重新處理,如果多次重試失敗則發出告警。

流程示意圖:
file
四、為什麼不用事務消息

由於是既有項目(互聯網金融,所以是絕對不容忍有任何消息丟失或者消息處理失敗)進行改造,不使用事務消息有1個原因

  • 需要額外引入消息隊列,增加系統的複雜度,而且也需要額外的邏輯保證和消息隊列通訊失敗的時候處理

  • 其實1不算是主要原因,而是因為事務消息需要手動的commit和rollback(使用資料庫不需要),那麼問題來了,spring中事務是有傳遞性的,那我們事務消息何時提交又是個大問題,例如 A.a()本來就是一個事務, 但是另外一個事務B.b()中又調用了A.a() 那事務消息提交是放在A.a()還是B.b()中呢?

本文由博客一文多發平臺 OpenWrite 發佈!


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

-Advertisement-
Play Games
更多相關文章
  • 最近發現了一個好玩,有趣的終端連接工具mobaxterm。Linux下有很多終端工具例如CRT,Xshell,但小伙伴就有疑問問什麼要用mobaxterm, 主要是mobaxterm是開源的免費的(其他都是收費的)。 廢話不多說我們立即進入正題。 下載與安裝。 0.打開你的瀏覽器:用CV大法進入官網 ...
  • 冒泡排序: 演算法重覆走訪要排序的數列,一次比較兩個元素,如果它們順序錯誤就交換它們的位置,這樣最大的數就到了最後,重覆操作即可得到有序數列。 冒泡排序演算法運行: 1. 比較相鄰的元素。如果第一個比第二個大,就交換他們兩個。 2. 對每一對相鄰元素作同樣的工作,從開始第一對到結尾的最後一對。在這一點, ...
  • 以下內容,來自網路資料整理和個人安裝使用結果。後續會持續更新 ...
  • 由於一些原因,我重新安裝了系統並把之前的鏡像與虛擬機刪除了,現在又全新安裝一次CenOS6.7,順便查缺補漏,帶領各位讀者一起安裝。 (本文適合小白/新人,大佬們請忽略),帶有可選步驟的可以忽略,1-20是VMware軟體的設置,系統的安裝從21-45條開始,剩餘部分是後續配置建議。如發現問題或有疑 ...
  • ver: 1.0 博客:https://www.cnblogs.com/Rohn 本文介紹了Shell常用的結構化語句。 數組 數組(Array)是若幹數據的集合,其中的每一份數據都稱為元素(Element)。 Bash只支持一維數組(不支持多維數組),初始化時不需要定義數組大小,理論上可以存放無限 ...
  • hbase2.1.9 centos7 完全分散式 搭建隨記 這裡是當初在三個ECS節點上搭建hadoop+zookeeper+hbase+solr的主要步驟,文章內容未經過潤色,請參考的同學搭配其他博客一同使用,並記得根據實際情況調整相關參數 1. 指定位置解壓 2. vi /etc/profile ...
  • zookeeper3.5.5 centos7 完全分散式 搭建隨記 這裡是當初在三個ECS節點上搭建hadoop+zookeeper+hbase+solr的主要步驟,文章內容未經過潤色,請參考的同學搭配其他博客一同使用,並記得根據實際情況調整相關參數 0.prepare 準備奇數台已經配置好jdk的 ...
  • Hadoop2.7.7 centos7 完全分散式 配置與問題隨記 這裡是當初在三個ECS節點上搭建hadoop+zookeeper+hbase+solr的主要步驟,文章內容未經過潤色,請參考的同學搭配其他博客一同使用,並記得根據實際情況調整相關參數。 0.prepare jdk,推薦1.8 關閉防 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:本文代碼示例演示瞭如何在WPF中使用LiveCharts庫創建動態條形圖。通過創建數據模型、ViewModel和在XAML中使用`CartesianChart`控制項,你可以輕鬆實現圖表的數據綁定和動態更新。我將通過清晰的步驟指南包括詳細的中文註釋,幫助你快速理解並應用這一功能。 先上效果: 在 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • 概述:本示例演示了在WPF應用程式中實現多語言支持的詳細步驟。通過資源字典和數據綁定,以及使用語言管理器類,應用程式能夠在運行時動態切換語言。這種方法使得多語言支持更加靈活,便於維護,同時提供清晰的代碼結構。 在WPF中實現多語言的一種常見方法是使用資源字典和數據綁定。以下是一個詳細的步驟和示例源代 ...
  • 描述(做一個簡單的記錄): 事件(event)的本質是一個委托;(聲明一個事件: public event TestDelegate eventTest;) 委托(delegate)可以理解為一個符合某種簽名的方法類型;比如:TestDelegate委托的返回數據類型為string,參數為 int和 ...
  • 1、AOT適合場景 Aot適合工具類型的項目使用,優點禁止反編 ,第一次啟動快,業務型項目或者反射多的項目不適合用AOT AOT更新記錄: 實實在在經過實踐的AOT ORM 5.1.4.117 +支持AOT 5.1.4.123 +支持CodeFirst和非同步方法 5.1.4.129-preview1 ...
  • 總說周知,UWP 是運行在沙盒裡面的,所有許可權都有嚴格限制,和沙盒外交互也需要特殊的通道,所以從根本杜絕了 UWP 毒瘤的存在。但是實際上 UWP 只是一個應用模型,本身是沒有什麼許可權管理的,許可權管理全靠 App Container 沙盒控制,如果我們脫離了這個沙盒,UWP 就會放飛自我了。那麼有沒... ...
  • 目錄條款17:讓介面容易被正確使用,不易被誤用(Make interfaces easy to use correctly and hard to use incorrectly)限制類型和值規定能做和不能做的事提供行為一致的介面條款19:設計class猶如設計type(Treat class de ...
  • title: 從零開始:Django項目的創建與配置指南 date: 2024/5/2 18:29:33 updated: 2024/5/2 18:29:33 categories: 後端開發 tags: Django WebDev Python ORM Security Deployment Op ...
  • 1、BOM對象 BOM:Broswer object model,即瀏覽器提供我們開發者在javascript用於操作瀏覽器的對象。 1.1、window對象 視窗方法 // BOM Browser object model 瀏覽器對象模型 // js中最大的一個對象.整個瀏覽器視窗出現的所有東西都 ...