欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL主從同步延遲的原因及解決辦法

 更新時間:2019年03月26日 09:55:32   作者:BrickCarrier  
今天小編就為大家分享一篇關(guān)于MySQL主從同步延遲的原因及解決辦法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧

由于歷史原因,MySQL復(fù)制基于邏輯的二進制日志,而非重做日志。多次被問到何時MySQL能支持基于物理的復(fù)制,其實這就看MySQL各位大佬的想法。上次和賴老師腦暴,倏地說道:MySQL會不會來個基于Paxos的redo復(fù)制?

物理復(fù)制的真正好處不在于正確性,因為基于ROW格式的日志復(fù)制也已能完全保證復(fù)制的正確性。由于物理日志的寫入是在事務(wù)執(zhí)行過程中就不斷寫入,而二進制日志的寫入僅僅在事務(wù)提交時。因此物理日志的優(yōu)勢如下所示:

  • 復(fù)制架構(gòu)下,大事務(wù)日志提交速度快;
  • 復(fù)制架構(gòu)下,主從數(shù)據(jù)延遲小;

假設(shè)執(zhí)行了1個小時的某大事務(wù),在最后提交時,只需寫入最后提交部分的重做日志(redo log可視為物理日志)。雖然此大事務(wù)重做日志寫入的總量可能有1G,然而在提交時,數(shù)據(jù)主從復(fù)制僅需將最后一部分日志傳輸?shù)竭h程從機,因為之前的重做日志已經(jīng)在執(zhí)行的1個小時內(nèi)不斷地同步到從機。

對于二進制日志,由于其寫入時間發(fā)生在事務(wù)提交時,因此假設(shè)產(chǎn)生了1G的二進制日志,則需要事務(wù)提交時間會包含這1G日志的寫入時間。在Oracle中有一種說法,事務(wù)的提交速度都是平的,不論事務(wù)的大小。這在MySQL數(shù)據(jù)庫中是不成立的。即,MySQL的提交速度取決于事務(wù)產(chǎn)生的二進制日志的大小,事務(wù)提交的速度不是平的。

更為糟糕的是,MySQL主從復(fù)制在大事務(wù)下的延遲。同樣假設(shè)1個大事務(wù)在主服務(wù)器上執(zhí)行了1個小時,則需要在最后的提交時間傳送到從服務(wù)器。主從延遲的時間至少為1個小時,若從服務(wù)器執(zhí)行還需1個小時,則主從復(fù)制延遲的最壞情況可能是2個小時。物理復(fù)制則不存在這樣的限制,原因還是如前所述,事務(wù)提交過程中,日志已經(jīng)在傳輸和回放。

物理復(fù)制雖好,但是也有自己的缺陷,就我自己的實際體驗來看:

  • 物理復(fù)制下,主機壞塊會導(dǎo)致主從服務(wù)器都無法啟動;相信遇到過此問題的同學(xué)不在少數(shù);
  • 此外,做ETL是有困難的,比如怎么將物理日志同步到Hadoop大數(shù)據(jù)平臺呢?

一言以蔽之,對于MySQL數(shù)據(jù)庫來說,任何時刻不允許有大事務(wù)執(zhí)行。若要執(zhí)行,則將大事務(wù)拆成一個個小的子事務(wù)來執(zhí)行。這是最基本心法口訣,但卻又和Oracle有著很大不同。總之,氣宗、劍宗,本無好壞,學(xué)會理解其中的差異,融會貫通方可達風(fēng)清揚般的致臻境界。

mysql 用主從同步的方法進行讀寫分離,減輕主服務(wù)器的壓力的做法現(xiàn)在在業(yè)內(nèi)做的非常普遍。 主從同步基本上能做到實時同步。我從別的網(wǎng)站借用了主從同步的原理圖。

在配置好了, 主從同步以后, 主服務(wù)器會把更新語句寫入binlog,   從服務(wù)器的IO 線程(這里要注意, 5.6.3 之前的IO線程僅有一個,5.6.3之后的有多線程去讀了,速度自然也就加快了)回去讀取主服務(wù)器的binlog 并且寫到從服務(wù)器的Relay log 里面,然后從服務(wù)器的 的SQL thread 會一個一個執(zhí)行 relay log 里面的sql , 進行數(shù)據(jù)恢復(fù)。

relay 就是 傳遞, relay race 就是接力賽的意思

1. 主從同步的延遲的原因

我們知道, 一個服務(wù)器開放N個鏈接給客戶端來連接的, 這樣有會有大并發(fā)的更新操作, 但是從服務(wù)器的里面讀取binlog 的線程僅有一個, 當某個SQL在從服務(wù)器上執(zhí)行的時間稍長 或者由于某個SQL要進行鎖表就會導(dǎo)致,主服務(wù)器的SQL大量積壓,未被同步到從服務(wù)器里。這就導(dǎo)致了主從不一致, 也就是主從延遲。

2. 主從同步延遲的解決辦法

實際上主從同步延遲根本沒有什么一招制敵的辦法, 因為所有的SQL必須都要在從服務(wù)器里面執(zhí)行一遍,但是主服務(wù)器如果不斷的有更新操作源源不斷的寫入, 那么一旦有延遲產(chǎn)生, 那么延遲加重的可能性就會原來越大。 當然我們可以做一些緩解的措施。

  • a. 我們知道因為主服務(wù)器要負責(zé)更新操作, 他對安全性的要求比從服務(wù)器高, 所有有些設(shè)置可以修改,比如sync_binlog=1,innodb_flush_log_at_trx_commit = 1 之類的設(shè)置,而slave則不需要這么高的數(shù)據(jù)安全,完全可以講sync_binlog設(shè)置為0或者關(guān)閉binlog,innodb_flushlog, innodb_flush_log_at_trx_commit 也 可以設(shè)置為0來提高sql的執(zhí)行效率 這個能很大程度上提高效率。另外就是使用比主庫更好的硬件設(shè)備作為slave。
  • b. 就是把,一臺從服務(wù)器當度作為備份使用, 而不提供查詢, 那邊他的負載下來了, 執(zhí)行relay log 里面的SQL效率自然就高了。
  • c. 增加從服務(wù)器嘍,這個目的還是分散讀的壓力, 從而降低服務(wù)器負載。

3. 判斷主從延遲的方法

MySQL提供了從服務(wù)器狀態(tài)命令,可以通過 show slave status 進行查看,  比如可以看看Seconds_Behind_Master參數(shù)的值來判斷,是否有發(fā)生主從延時。

其值有這么幾種:

NULL - 表示io_thread或是sql_thread有任何一個發(fā)生故障,也就是該線程的Running狀態(tài)是No,而非Yes.
0 - 該值為零,是我們極為渴望看到的情況,表示主從復(fù)制狀態(tài)正常

其它的方法我也沒試過, 暫時不做評論

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接

相關(guān)文章

  • Win10環(huán)境下安裝Mysql5.7.23問題及遇到的坑

    Win10環(huán)境下安裝Mysql5.7.23問題及遇到的坑

    這篇文章主要介紹了Win10環(huán)境下安裝Mysql5.7.23問題及遇到的坑,本文通過圖文并茂的形式給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-11-11
  • 解析MySQL中mysqldump工具的基本用法

    解析MySQL中mysqldump工具的基本用法

    本篇文章是對MySQL中mysqldump工具的基本用法進行了詳細的分析介紹,需要的朋友參考下
    2013-06-06
  • MySQL8.0 Undo Tablespace管理詳解

    MySQL8.0 Undo Tablespace管理詳解

    本文主要介紹了MySQL8.0 Undo Tablespace管理詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • MySQL常見的底層優(yōu)化操作教程及相關(guān)建議

    MySQL常見的底層優(yōu)化操作教程及相關(guān)建議

    這篇文章主要介紹了MySQL常見的底層優(yōu)化操作教程及相關(guān)建議,包括對運行操作系統(tǒng)的硬件方面及存儲引擎參數(shù)的調(diào)整等零碎方面的小整理,需要的朋友可以參考下
    2015-12-12
  • Mysql基礎(chǔ)學(xué)習(xí)之LAG與LEAD開窗函數(shù)

    Mysql基礎(chǔ)學(xué)習(xí)之LAG與LEAD開窗函數(shù)

    lead和lag是在SQL中用于創(chuàng)建窗口函數(shù)的兩個常用函數(shù),這篇文章主要給大家介紹了關(guān)于Mysql基礎(chǔ)學(xué)習(xí)之LAG與LEAD開窗函數(shù)的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-11-11
  • mysql 8.0.11 壓縮包版安裝配置方法圖文教程

    mysql 8.0.11 壓縮包版安裝配置方法圖文教程

    這篇文章主要為大家詳細介紹了mysql 8.0.11 壓縮包版安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • 關(guān)于mysql 的時間類型選擇

    關(guān)于mysql 的時間類型選擇

    本篇文章是對mysql中的時間類型選擇進行了詳細的分析介紹,需要的朋友參考下
    2013-06-06
  • MySQL中Navicat自動備份的實現(xiàn)

    MySQL中Navicat自動備份的實現(xiàn)

    本文主要介紹了MySQL中Navicat自動備份的實現(xiàn),包括手動備份和自動定時備份,文中通過圖文示例介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2025-03-03
  • Windows中MySQL root用戶忘記密碼解決方案

    Windows中MySQL root用戶忘記密碼解決方案

    在實際應(yīng)用中,經(jīng)常會出現(xiàn)忘記mysql管理員用戶root的密碼的情況出現(xiàn),那么我們?nèi)绾蝸碓O(shè)置一個新密碼從而登錄數(shù)據(jù)庫呢,下面我們來探討下
    2014-07-07
  • 使用MySQL建立外鍵約束時報錯3780的解決方案

    使用MySQL建立外鍵約束時報錯3780的解決方案

    在創(chuàng)建MySQL外鍵約束時,報錯3780通常是因為主表和從表中對應(yīng)字段的數(shù)據(jù)類型不一致,使用Navicat可視化界面修改數(shù)據(jù)類型,即可解決此問題,這是一個常見的數(shù)據(jù)庫設(shè)計錯誤,確保數(shù)據(jù)類型一致是關(guān)鍵
    2024-11-11

最新評論