首頁 > 資料庫 > mysql教程 > 一起聊聊MySQL主從延時的處理方案

一起聊聊MySQL主從延時的處理方案

WBOY
發布: 2022-01-17 18:28:38
轉載
2127 人瀏覽過

這篇文章為大家帶來了關於mysql中主從延時處理方案的相關知識,MySQL主從複製,讀寫分離是互聯網常見的資料庫架構,該架構最令人詬病的地方就是,在在資料量較大且發量較大的場景下,主從延時會比較嚴重。希望對大家有幫助。

一起聊聊MySQL主從延時的處理方案

為什麼主從延時這麼大?

一起聊聊MySQL主從延時的處理方案

#答案:MySQL使用單執行緒重播RelayLog。

該怎麼優化,縮短重播時間?

答案:多執行緒並行重播RelayLog可以縮短時間。

多執行緒並行重播RelayLog有什麼問題?

一起聊聊MySQL主從延時的處理方案

答案:需要考慮如何分割RelayLog,才能讓多個資料庫實例,多個執行緒並行重播RelayLog,不會出現不一致。

為什麼會出現不一致?

答案:如果RelayLog隨機的分配給不同的重播線程,假設RelayLog中有這樣三個序列的修改記錄:

update account set money=100 where uid=58;

update account set money=150 where uid=58;

update account set money=200 where uid=58;

如果單執行緒串列重播:能確保所有從庫與主庫的執行序列一致。

畫外音:最後money都會為200。

如果多執行緒隨機分配重播:多重放執行緒並發執行這3個語句,誰最後執行是不確定的,最終從函式庫資料可能與主函式庫不同。

畫外音:多個從庫可能money為100,150,200不確定。

如何分配,多個從函式庫多執行緒重播,也能得到一致的資料呢?

答案:在相同函式庫上的寫入操作,用相同的執行緒來重播RelayLog;不同函式庫上的寫入操作,可以並發多個執行緒並發來重播RelayLog。

一起聊聊MySQL主從延時的處理方案

如何做到?

答案:設計一個雜湊演算法,hash(db-name) % thread-num,庫名hash之後再模上執行緒數,就能很輕易做到,同一個庫上的寫入操作,被同一個重播執行緒串列執行。

畫外音:不同函式庫上的重放,是並行的,就起到了加速做用。

這個方案有什麼不足之處?

答:很多公司對MySQL的使用是“單庫多表”,如果是這樣的話,仍然只有一個庫,還是不能提高RelayLog的重播速度。

啟示:將「單庫多表」的DB架構模式升級為「多庫多表」的DB架構模式。

畫外音:資料量大並發量大的網路業務場景,「多庫」模式還具備其他許多優勢,例如:

(1)非常方便的實例擴充:DBA很容易將不同的函式庫擴展到不同的實例;

(2)依照業務進行函式庫隔離:業務解耦,進行業務隔離,減少耦合與相互影響;

(3)非常方便微服務拆分:每個服務擁有自己的實例就方便了;

「單庫多表」的場景,多執行緒並行重播RelayLog還能怎麼優化?

答:即使只有一個庫,事務在主庫上也是並發執行的,既然在主庫上可以並行執行,在從庫上也應該能夠並行執行呀?

新想法:將主庫上同時並行執行的事務,分為一組,編一個號,這些事務在從庫上的回放可以並行執行(事務在主庫上的執行都進入到prepare階段,表示事務之間沒有衝突,否則就不可能提交),沒錯,MySQL正是這麼做的。

解法:基於GTID的平行複製。

從MySQL5.7開始,將群組提交的資訊存放在GTID中,使用mysqlbinlog工具,可以看到群組提交內部的資訊:

20181014 23:52 server_id 58 XXX GTID last_committed=0 sequence_numer=1
20181014 23:52 server_id 58 XXX GTID last_committed=0 sequence_numer=2
20181014 23:52 server_id 58 XXX GTID last_committed=0 sequence_numer=3
20181014 23:52 server_id 58 XXX GTID last_committed=0 sequence_numer=4
登入後複製

一起聊聊MySQL主從延時的處理方案

和原來的日誌相比,多了last_committed和sequence_number。

什麼是last_committed?

答:它是交易提交時,上次交易提交的編號,如果具備相同的last_committed,說明它們在一個群組內,可以並發回放執行。

總結

MySQL並行複製,縮短主從同步時延的方法,體現著這樣的一些架構想法:

多執行緒是一種常見的縮短執行時間的方法;

畫外音:例如,很多crontab可以用多線程,切分數據,並行執行。

多執行緒並發分派任務時,必須保證冪等性:MySQL提供了“按照函式庫冪等”,“依照commit_id冪等”兩種方式,很值得藉鏡;

畫外音:例如,群組訊息,可以依照group_id冪等;使用者訊息,可以依照user_id冪等。

具體到MySQL主從同步延遲:

mysql5.5:不支援並行複製,大夥快升級MySQL版本;

mysql5.6:依照函式庫並行複製,建議使用「多庫」架構;

mysql5.7:按照GTID並行複製;

推薦學習:mysql影片教學

#######

以上是一起聊聊MySQL主從延時的處理方案的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:juejin.im
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板