一般而言,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的進度,可以嘗試采用以下幾種方法: