溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

MySQL主從延遲解決方法的歸納和總結(jié)

發(fā)布時(shí)間:2020-08-09 22:48:37 來源:ITPUB博客 閱讀:181 作者:chenfeng 欄目:MySQL數(shù)據(jù)庫
MySQL主從延遲情況共分為以下四類
一.MIXED模式無索引或SQL慢
在從庫上
pager grep -v Sleep;show processlist 查看到正在執(zhí)行的SQL
解決方法:
1.SQL比較簡單,則檢查否缺少索引,并添加索引。例如update操作where條件無索引。
2.SQL比較復(fù)雜,例如insert into select from語句,如果select里包含group by,多表關(guān)聯(lián),可能效率會(huì)比較低。這類可以到主庫把binlog_format改為row.

二.主庫上有大事務(wù),導(dǎo)致從庫延時(shí)
解決方法:
找開發(fā)人員溝通,增加緩存,異步寫入數(shù)據(jù)庫,減少對(duì)DB的大量寫入。

三.主庫寫入頻繁,從庫壓力跟不上主庫導(dǎo)致延時(shí)
此類原因的主要現(xiàn)象是數(shù)據(jù)庫的IUD(增改刪)操作非常多,slave由于sql_thread單線程的原因追不上主庫的寫操作。
解決方法:
1.升級(jí)主庫的硬件配置,比如ssd、fio
2.設(shè)置日志刷新頻率:
set global_sync_binlog=0;
  •   innodb_flush_log_at_trx_commit=0每秒將log_buffer的內(nèi)容刷新到logfile,并且將日志同步刷新到磁盤。該模式下,在事務(wù)提交的時(shí)候,不會(huì)主動(dòng)觸發(fā)寫入磁盤的操作。
  •   innodb_flush_log_at_trx_commit=1每次commit將log_buffer刷新到logfile,并且將日志同步刷新到磁盤。
  •   innodb_flush_log_at_trx_commit=2每次commit將log_buffer刷新到logfile,但是flush(刷到磁盤)操作并不會(huì)同時(shí)進(jìn)行,每秒將日志刷新到磁盤。

四.數(shù)據(jù)庫中存在大量myisam表,在備份的時(shí)候?qū)е聫膸煅舆t
由于xtrabackup工具備份到最后會(huì)執(zhí)行flush tables with read lock,對(duì)數(shù)據(jù)庫進(jìn)行鎖表以便進(jìn)行一致性備份,然后對(duì)于myisam表鎖,會(huì)阻礙slave sql_thread線程停滯運(yùn)行而導(dǎo)致hang。
該問題目前比較好的解決方法是修改表結(jié)構(gòu)為innod存儲(chǔ)引擎的表。
向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI