程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> slave延遲原因及優化方法,slave延遲優化

slave延遲原因及優化方法,slave延遲優化

編輯:MySQL綜合教程

slave延遲原因及優化方法,slave延遲優化


轉載:http://imysql.com/2015/04/12/mysql-optimization-case-howto-resolve-slave-delay.shtml

一般而言,slave相對master延遲較大,其根本原因就是slave上的復制線程沒辦法真正做到並發。簡單說,在master上是並發模式(以InnoDB引擎為主)完成事務提交的,而在slave上,復制線程只有一個sql thread用於binlog的apply,所以難怪slave在高並發時會遠落後master。

ORACLE MySQL 5.6版本開始支持多線程復制,配置選項 slave_parallel_workers 即可實現在slave上多線程並發復制。不過,它只能支持一個實例下多個 database 間的並發復制,並不能真正做到多表並發復制。因此在較大並發負載時,slave還是沒有辦法及時追上master,需要想辦法進行優化。

另一個重要原因是,傳統的MySQL復制是異步(asynchronous)的,也就是說在master提交完後,才在slave上再應用一遍,並不是真正意義上的同步。哪怕是後來的Semi-sync Repication(半同步復制),也不是真同步,因為它只保證事務傳送到slave,但沒要求等到確認事務提交成功。既然是異步,那肯定多少會有延遲。因此,嚴格意義上講,MySQL復制不能叫做MySQL同步(處女座的面試官有可能會在面試時把說成MySQL同步的一律刷掉哦)。

另外,不少人的觀念裡,slave相對沒那麼重要,因此就不會提供和master相同配置級別的服務器。有的甚至不但使用更差的服務器,而且還在上面跑多實例。

綜合這兩個主要原因,slave想要盡可能及時跟上master的進度,可以嘗試采用以下幾種方法:

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved