明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

從以下幾個方面來處理,MySQL主從復制不一致的問題

[摘要]在搭建Mysql主從配置的時候,常常會出現(xiàn)主從不同步,或者是說有誤差,有延遲的情況,下面我們可以根據(jù)這幾個方面進行錯誤的排查。稍微有些規(guī)模的網(wǎng)站,基本上都會配置mysql主從復制,一方面用mysql...
在搭建Mysql主從配置的時候,常常會出現(xiàn)主從不同步,或者是說有誤差,有延遲的情況,下面我們可以根據(jù)這幾個方面進行錯誤的排查。


稍微有些規(guī)模的網(wǎng)站,基本上都會配置mysql主從復制,一方面用mysql的主從做數(shù)據(jù)庫的讀寫分離,另一方面mysql本身的單機備份不是很強,一般采用主從架構,在從上進行數(shù)據(jù)備份。

在MySQL主從復制過程中或多或少出現(xiàn)一些主從不同步的情況,本文將對數(shù)據(jù)主從不同步的情況進行簡單的總結,請注意本文主要從數(shù)據(jù)庫層面上探討數(shù)據(jù)庫的主從不一致的情況。
1.網(wǎng)絡的延遲

由于mysql主從復制是基于binlog的一種異步復制,通過網(wǎng)絡傳送binlog文件,理所當然網(wǎng)絡延遲是主從不同步的絕大多數(shù)的原因,特別是跨機房的數(shù)據(jù)同步出現(xiàn)這種幾率非常的大,所以做讀寫分離,注意從業(yè)務層進行前期設計。

2.主從兩臺機器的負載不一致

由于mysql主從復制是主數(shù)據(jù)庫上面啟動1個io線程,而從上面啟動1個sql線程和1個io線程,當中任何一臺機器的負載很高,忙不過來,導致其中的任何一個線程出現(xiàn)資源不足,都將出現(xiàn)主從不一致的情況。

3.max_allowed_packet設置不一致

主數(shù)據(jù)庫上面設置的max_allowed_packet比從數(shù)據(jù)庫大,當一個大的sql語句,能在主數(shù)據(jù)庫上面執(zhí)行完畢,從數(shù)據(jù)庫上面設置過小,無法執(zhí)行,導致的主從不一致。

4.key自增鍵開始的鍵值跟自增步長設置不一致引起的主從不一致

5.mysql異常宕機情況下,如果未設置sync_binlog=1或者innodb_flush_log_at_trx_commit=1很有可能出現(xiàn)binlog或者relaylog文件出現(xiàn)損壞,導致主從不一致。

6.mysql本身的bug引起的主從不同步。

7.版本不一致,特別是高版本是主,低版本為從的情況下,主數(shù)據(jù)庫上面支持的功能,從數(shù)據(jù)庫上面不支持該功能。

以上就是常見的一些主從不同步的情況。或許還有其他的一些不同步的情況,請說出你所遇到的主從不一致的情況。

基于以上情況,先保證max_allowed_packet、自增鍵開始點和增長點設置一致,再者犧牲部分性能在主上面開啟sync_binlog,對于采用innodb的庫,推薦配置下面的內容

1、innodb_flush_logs_at_trx_commit = 1
2、innodb-support_xa = 1 # Mysql 5.0 以上
3、innodb_safe_binlog # Mysql 4.0

同時在從數(shù)據(jù)庫上面推薦加入下面兩個參數(shù)

1、skip_slave_start
2、read_only

以上是在Mysql搭建的主從環(huán)境下出現(xiàn)問題的解決方法,希望對大家有所幫助。

相關文章:

Mycat讀寫分離在MySQL主從復制基礎上實現(xiàn)的實例

如何利用docker快速構建MySQL主從復制環(huán)境的詳情介紹

以上就是從以下幾個方面來處理,MySQL主從復制不一致的問題的詳細內容,更多請關注php中文網(wǎng)其它相關文章!


學習教程快速掌握從入門到精通的SQL知識。