<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

        MYSQL主從不同步延遲原理分析及解決方案

        來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-09 21:06:05
        文檔

        MYSQL主從不同步延遲原理分析及解決方案

        MYSQL主從不同步延遲原理分析及解決方案:1. MySQL數(shù)據(jù)庫主從同步延遲原理。要說延時原理,得從mysql的數(shù)據(jù)庫主從復(fù)制原理說起,mysql的主從復(fù)制都是單線程的操作,主庫對所有DDL和DML產(chǎn)生binlog,binlog是順序?qū)懀孕屎芨撸瑂lave的Slave_IO_Running線程到主庫取日志,效率很比較高,下一
        推薦度:
        導(dǎo)讀MYSQL主從不同步延遲原理分析及解決方案:1. MySQL數(shù)據(jù)庫主從同步延遲原理。要說延時原理,得從mysql的數(shù)據(jù)庫主從復(fù)制原理說起,mysql的主從復(fù)制都是單線程的操作,主庫對所有DDL和DML產(chǎn)生binlog,binlog是順序?qū)懀孕屎芨撸瑂lave的Slave_IO_Running線程到主庫取日志,效率很比較高,下一

        1. MySQL數(shù)據(jù)庫主從同步延遲原理。
        要說延時原理,得從mysql的數(shù)據(jù)庫主從復(fù)制原理說起,mysql的主從復(fù)制都是單線程的操作,
        主庫對所有DDL和DML產(chǎn)生binlog,binlog是順序?qū)懀孕屎芨撸瑂lave的Slave_IO_Running線程到主庫取日志,效率很比較高,下一步,問題來了,slave的Slave_SQL_Running線程將主庫的DDL和DML操作在slave實施。DML和DDL的IO操作是隨即的,不是順序的,成本高很多,還可能可slave上的其他查詢產(chǎn)生lock爭用,由于Slave_SQL_Running也是單線程的,所以一個DDL卡主了,需要執(zhí)行10分鐘,那么所有之后的DDL會等待這個DDL執(zhí)行完才會繼續(xù)執(zhí)行,這就導(dǎo)致了延時。有朋友會問:“主庫上那個相同的DDL也需要執(zhí)行10分,為什么slave會延時?”,答案是master可以并發(fā),Slave_SQL_Running線程卻不可以。

        2. MySQL數(shù)據(jù)庫主從同步延遲是怎么產(chǎn)生的。
        當(dāng)主庫的TPS并發(fā)較高時,產(chǎn)生的DDL數(shù)量超過slave一個sql線程所能承受的范圍,那么延時就產(chǎn)生了,當(dāng)然還有就是可能與slave的大型query語句產(chǎn)生了鎖等待。

        3. MySQL數(shù)據(jù)庫主從同步延遲解決方案。
        丁奇的transefer是一個不錯的方案,不過一般公司受限于對mysql的代碼修改能力的限制和對mysql的掌控能力,還是不太適合。
        最簡單的減少slave同步延時的方案就是在架構(gòu)上做優(yōu)化,盡量讓主庫的DDL快速執(zhí)行。還有就是主庫是寫,對數(shù)據(jù)安全性較高,比如sync_binlog=1,innodb_flush_log_at_trx_commit = 1 之類的設(shè)置,而slave則不需要這么高的數(shù)據(jù)安全,完全可以講sync_binlog設(shè)置為0或者關(guān)閉binlog,innodb_flushlog也可以設(shè)置為0來提高sql的執(zhí)行效率。另外就是使用比主庫更好的硬件設(shè)備作為slave。
        mysql-5.6.3已經(jīng)支持了多線程的主從復(fù)制。原理和丁奇的類似,丁奇的是以表做多線程,oracle使用的是以數(shù)據(jù)庫(schema)為單位做多線程,不同的庫可以使用不同的復(fù)制線程。

        sync_binlog=1 o
             This makes MySQL synchronize the binary log's contents to disk each time it commits a transaction
             默認情況下,并不是每次寫入時都將binlog與硬盤同步。因此如果操作系統(tǒng)或機器(不僅僅是MySQL服務(wù)器)崩潰,有可能binlog中最后的語句丟 失了。要想防止這種情況,你可以使用sync_binlog全局變量(1是最安全的值,但也是最慢的),使binlog在每N次binlog寫入后與硬盤 同步。即使sync_binlog設(shè)置為1,出現(xiàn)崩潰時,也有可能表內(nèi)容和binlog內(nèi)容之間存在不一致性。如果使用InnoDB表,MySQL服務(wù)器 處理COMMIT語句,它將整個事務(wù)寫入binlog并將事務(wù)提交到InnoDB中。如果在兩次操作之間出現(xiàn)崩潰,重啟時,事務(wù)被InnoDB回滾,但仍 然存在binlog中。可以用--innodb-safe-binlog選項來增加InnoDB表內(nèi)容和binlog之間的一致性。(注釋:在MySQL 5.1中不需要--innodb-safe-binlog;由于引入了XA事務(wù)支持,該選項作廢了),該選項可以提供更大程度的安全,使每個事務(wù)的 binlog(sync_binlog =1)和(默認情況為真)InnoDB日志與硬盤同步,該選項的效果是崩潰后重啟時,在滾回事務(wù)后,MySQL服務(wù)器從binlog剪切回滾的 InnoDB事務(wù)。這樣可以確保binlog反饋InnoDB表的確切數(shù)據(jù)等,并使從服務(wù)器保持與主服務(wù)器保持同步(不接收 回滾的語句)。

        innodb_flush_log_at_trx_commit (這個很管用)
        抱怨Innodb比MyISAM慢 100倍?那么你大概是忘了調(diào)整這個值。默認值1的意思是每一次事務(wù)提交或事務(wù)外的指令都需要把日志寫入(flush)硬盤,這是很費時的。特別是使用電 池供電緩存(Battery backed up cache)時。設(shè)成2對于很多運用,特別是從MyISAM表轉(zhuǎn)過來的是可以的,它的意思是不寫入硬盤而是寫入系統(tǒng)緩存。日志仍然會每秒flush到硬 盤,所以你一般不會丟失超過1-2秒的更新。設(shè)成0會更快一點,但安全方面比較差,即使MySQL掛了也可能會丟失事務(wù)的數(shù)據(jù)。而值2只會在整個操作系統(tǒng) 掛了時才可能丟數(shù)據(jù)。

        您可能感興趣的文章:

      1. MySQL中從庫延遲狀況排查的一則案例
      2. 減少mysql主從數(shù)據(jù)同步延遲問題的詳解
      3. 解決MySQL中的Slave延遲問題的基本教程
      4. mysql同步問題之Slave延遲很大優(yōu)化方法
      5. MySQL延遲關(guān)聯(lián)性能優(yōu)化方法
      6. mySQL 延遲 查詢主表
      7. 深入mysql主從復(fù)制延遲問題的詳解
      8. 部署MySQL延遲從庫的一些好處小結(jié)
      9. 聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        MYSQL主從不同步延遲原理分析及解決方案

        MYSQL主從不同步延遲原理分析及解決方案:1. MySQL數(shù)據(jù)庫主從同步延遲原理。要說延時原理,得從mysql的數(shù)據(jù)庫主從復(fù)制原理說起,mysql的主從復(fù)制都是單線程的操作,主庫對所有DDL和DML產(chǎn)生binlog,binlog是順序?qū)懀孕屎芨撸瑂lave的Slave_IO_Running線程到主庫取日志,效率很比較高,下一
        推薦度:
        標(biāo)簽: 同步 延遲 延時
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 一级特级女人18毛片免费视频| 亚洲av永久综合在线观看尤物| 亚洲欧美熟妇综合久久久久| xxxx日本免费| 亚洲日本在线播放| 又黄又爽又成人免费视频| 亚洲人成电影在线观看网| 永久免费av无码网站韩国毛片 | 1000部啪啪毛片免费看| 久久精品蜜芽亚洲国产AV| 最近中文字幕免费mv在线视频| 亚洲香蕉免费有线视频| 亚洲一区二区三区免费视频| 在线亚洲午夜片AV大片| 麻豆精品国产免费观看| 看成年女人免费午夜视频| 亚洲人成色77777在线观看大| 成人A毛片免费观看网站| 亚洲AV日韩AV永久无码绿巨人| 9420免费高清在线视频| 午夜在线a亚洲v天堂网2019| 巨胸喷奶水视频www网免费| 国产成人亚洲午夜电影| 国产精品亚洲а∨无码播放| 最近2019中文字幕免费大全5| 中文有码亚洲制服av片| 亚洲日本韩国在线| 久久精品成人免费观看| 亚洲首页国产精品丝袜| 亚洲国产a级视频| 暖暖在线视频免费视频| 亚洲国产精品无码久久久秋霞1| 亚洲一本大道无码av天堂| 亚州免费一级毛片| 曰批全过程免费视频免费看| 2022年亚洲午夜一区二区福利| 日韩精品免费一区二区三区| 国产精品免费大片| 国产大陆亚洲精品国产| 亚洲最新在线视频| 亚洲日韩国产一区二区三区|