欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳細(xì)分析MySQL主從復(fù)制

 更新時(shí)間:2020年08月15日 16:04:27   作者:MySQL技術(shù)  
這篇文章主要介紹了MySQL主從復(fù)制的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)MySQL,感興趣的朋友可以了解下

前言:

在MySQL中,主從架構(gòu)應(yīng)該是最基礎(chǔ)、最常用的一種架構(gòu)了。后續(xù)的讀寫分離、多活高可用架構(gòu)等大多都依賴于主從復(fù)制。主從復(fù)制也是我們學(xué)習(xí)MySQL過程中必不可少的一部分,關(guān)于主從復(fù)制的文章有很多,筆者也來湊湊熱鬧,寫寫這方面的內(nèi)容吧,同時(shí)分享下自己的經(jīng)驗(yàn)和方法。

1.主從復(fù)制簡(jiǎn)介及原理

主從復(fù)制(也稱 AB 復(fù)制)是指一臺(tái)服務(wù)器充當(dāng)主數(shù)據(jù)庫(kù)服務(wù)器,另一臺(tái)或多臺(tái)服務(wù)器充當(dāng)從數(shù)據(jù)庫(kù)服務(wù)器,主服務(wù)器中的數(shù)據(jù)自動(dòng)復(fù)制到從服務(wù)器之中。對(duì)于多級(jí)復(fù)制,數(shù)據(jù)庫(kù)服務(wù)器既可充當(dāng)主機(jī),也可充當(dāng)從機(jī)。MySQL默認(rèn)采用異步復(fù)制方式。

主從復(fù)制的過程及原理可以總結(jié)如下:

  1. master服務(wù)器將數(shù)據(jù)的改變記錄二進(jìn)制binlog日志,當(dāng)master上的數(shù)據(jù)發(fā)生改變時(shí),則將其改變寫入二進(jìn)制日志中。
  2. slave服務(wù)器會(huì)在一定時(shí)間間隔內(nèi)對(duì)master二進(jìn)制日志進(jìn)行探測(cè)其是否發(fā)生改變,如果發(fā)生改變,則開始一個(gè)I/OThread請(qǐng)求master二進(jìn)制事件。
  3. 同時(shí)主節(jié)點(diǎn)為每個(gè)I/O線程啟動(dòng)一個(gè)dump線程,用于向其發(fā)送二進(jìn)制事件,并保存至從節(jié)點(diǎn)本地的中繼日志中,從節(jié)點(diǎn)將啟動(dòng)SQL線程從中繼日志中讀取二進(jìn)制日志,在本地重放,使得其數(shù)據(jù)和主節(jié)點(diǎn)的保持一致。

 2.基于二進(jìn)制文件位置配置主從復(fù)制

基于二進(jìn)制文件位置的主從復(fù)制又可以稱為傳統(tǒng)復(fù)制,即從服務(wù)器依賴于主服務(wù)器的binlog文件位置,當(dāng)主庫(kù)發(fā)生數(shù)據(jù)變更時(shí),binlog pos位點(diǎn)會(huì)增長(zhǎng),從庫(kù)會(huì)感應(yīng)到變化來完成同步。

配置主從復(fù)制,我們首先要準(zhǔn)備至少兩臺(tái)MySQL實(shí)例,一臺(tái)充當(dāng)主服務(wù)器、一臺(tái)充當(dāng)從服務(wù)器。由于主從復(fù)制依賴于binlog,所以主庫(kù)必須開啟binlog,且主從要配置不同的server_id,下面具體展示下配置過程:

2.1 確認(rèn)主從庫(kù)配置參數(shù)

MySQL主從服務(wù)器建議有如下配置,可以先確認(rèn)下,如果未配置,則需要修改配置文件然后重啟。

# 主庫(kù)參數(shù)配置 要有以下參數(shù)
vim /etc/my.cnf 
[mysqld] 
log-bin = binlog //啟用二進(jìn)制日志
server-id = 137 //服務(wù)器唯一ID,默認(rèn)值是1,一般設(shè)置為IP地址的最后一段數(shù)字
binlog_format = row //bilog設(shè)置為row模式 防止復(fù)制出錯(cuò)

# 從庫(kù)建議配置以下參數(shù)
vim /etc/my.cnf 
[mysqld] 
relay-log = relay-bin
server-id = 138

2.2 確定主庫(kù)二進(jìn)制位置,創(chuàng)建同步賬號(hào)

若主從庫(kù)都是剛剛初始化完成,且主庫(kù)無操作時(shí),從庫(kù)可不用同步主庫(kù)的數(shù)據(jù),直接確定主庫(kù)的binlog位置即可。

# 查看主庫(kù)binlog文件位置
show master status;

# 主庫(kù)創(chuàng)建同步賬號(hào)
create user 'repl'@'%' identified by '123456';
grant replication slave on *.* to 'repl'@'%';

若主庫(kù)已經(jīng)運(yùn)行了一段時(shí)間,有業(yè)務(wù)數(shù)據(jù)在,而從庫(kù)剛剛初始化完成,此時(shí)則需要備份主庫(kù)的數(shù)據(jù),然后導(dǎo)入從庫(kù),使得主從數(shù)據(jù)一致。

# 主庫(kù)創(chuàng)建同步賬號(hào)
create user 'repl'@'%' identified by '123456';
grant replication slave on *.* to 'repl'@'%';

# 全備主庫(kù)數(shù)據(jù)
mysqldump -uroot -pxxxx -A -R -E --single-transaction --master-data=2 > all_db.sql

# 從庫(kù)端恢復(fù)
mysql -uroot -pxxxx < all_db.sql

# 從備份文件中可以找到主庫(kù)的binlog位置

2.3 進(jìn)入從庫(kù),開啟主從復(fù)制

找到主庫(kù)二進(jìn)制文件位置且完成主從數(shù)據(jù)一致后,我們就可以正式開啟主從復(fù)制了。

# 進(jìn)入從庫(kù)MySQL命令行 執(zhí)行change master語(yǔ)句連接主庫(kù)
# 二進(jìn)制文件名及pos位置由上面步驟獲得
CHANGE MASTER TO MASTER_HOST='MySQL主服務(wù)器IP地址',
 MASTER_PORT=3306,
 MASTER_USER='repl',
 MASTER_PASSWORD='123456',
 MASTER_LOG_FILE='binlog.000002',
 MASTER_LOG_POS=154;
 
# 開啟主從復(fù)制 并堅(jiān)持狀態(tài)
start slave;
show slave status \G //查看slave狀態(tài) 確保Slave_IO_Running: Yes Slave_SQL_Running: Yes

3.基于GTID的主從復(fù)制

GTID是MySQL 5.6的新特性,其全稱是Global Transaction Identifier,可簡(jiǎn)化MySQL的主從切換以及Failover。GTID用于在binlog中唯一標(biāo)識(shí)一個(gè)事務(wù)。當(dāng)事務(wù)提交時(shí),MySQL Server在寫binlog的時(shí)候,會(huì)先寫一個(gè)特殊的Binlog Event,類型為GTID_Event,指定下一個(gè)事務(wù)的GTID,然后再寫事務(wù)的Binlog。

在基于GTID的復(fù)制中,首先從服務(wù)器會(huì)告訴主服務(wù)器已經(jīng)在從服務(wù)器執(zhí)行完了哪些事務(wù)的GTID值,然后主庫(kù)會(huì)有把所有沒有在從庫(kù)上執(zhí)行的事務(wù),發(fā)送到從庫(kù)上進(jìn)行執(zhí)行,并且使用GTID的復(fù)制可以保證同一個(gè)事務(wù)只在指定的從庫(kù)上執(zhí)行一次,這樣可以避免由于偏移量的問題造成數(shù)據(jù)不一致。也就是說,無論是級(jí)聯(lián)情況,還是一主多從的情況,都可以通過GTID自動(dòng)找位置,而無需像之前那樣通過File_name和File_position找主庫(kù)binlog位置了。

基于GTID的主從復(fù)制與上面基于二進(jìn)制文件位置的主從復(fù)制搭建步驟類似,同樣簡(jiǎn)單展示下搭建過程:

3.1 確認(rèn)主從庫(kù)配置,開啟GTID

# 主庫(kù)參數(shù)配置 要有以下參數(shù)
vim /etc/my.cnf 
[mysqld] 
server-id = 137
log-bin = binlog 
binlog_format = row 
gtid-mode = ON //開啟gtid模式
enforce-gtid-consistency = ON //強(qiáng)制gtid一致性,用于保證啟動(dòng)gitd后事務(wù)的安全 

# 從庫(kù)建議配置以下參數(shù)
vim /etc/my.cnf 
[mysqld] 
server-id = 138
log-bin = binlog 
binlog_format = row 
gtid-mode = ON 
enforce-gtid-consistency = ON 
relay-log = relay-bin

3.2 創(chuàng)建同步賬號(hào),保持主從庫(kù)數(shù)據(jù)一致

若主庫(kù)剛初始化完成或者主庫(kù)端保留有全部二進(jìn)制文件,則從庫(kù)無需手動(dòng)同步數(shù)據(jù)。否則需要手動(dòng)同步數(shù)據(jù)使得主從一致。

# 主庫(kù)創(chuàng)建同步賬號(hào)
create user 'repl'@'%' identified by '123456';
grant replication slave on *.* to 'repl'@'%';

# 若主庫(kù)剛初始化或保留有完整二進(jìn)制文件 則無需執(zhí)行下面步驟
# 全備主庫(kù)數(shù)據(jù)
mysqldump -uroot -pxxxx -A -R -E --single-transaction > all_db.sql
# 從庫(kù)端恢復(fù)
mysql -uroot -pxxxx < all_db.sql

3.3 進(jìn)入從庫(kù),開啟主從復(fù)制

# 進(jìn)入從庫(kù)MySQL命令行 執(zhí)行change master語(yǔ)句連接主庫(kù)
CHANGE MASTER TO MASTER_HOST='MySQL主服務(wù)器IP地址',
 MASTER_PORT=3306,
 MASTER_USER='repl',
 MASTER_PASSWORD='123456',
 MASTER_AUTO_POSITION = 1;
 
# 開啟主從復(fù)制 并堅(jiān)持狀態(tài)
start slave;
show slave status \G

 4.一些經(jīng)驗(yàn)及建議

在日常學(xué)習(xí)及工作過程中,主從復(fù)制方面也積累了一些經(jīng)驗(yàn),下面簡(jiǎn)單分享幾點(diǎn),希望各位少踩坑。

  • 主從兩端數(shù)據(jù)庫(kù)版本盡量保持一致。
  • 主從庫(kù)參數(shù)建議相同,比如字符集、sql_mode這類參數(shù)要設(shè)置一樣。
  • 從庫(kù)服務(wù)器性能不能過于落后主庫(kù),以免因服務(wù)器性能產(chǎn)生主從延遲。
  • 所有表強(qiáng)制擁有主鍵,因?yàn)闊o主鍵表同步到從庫(kù)極易產(chǎn)生主從延遲。
  • 建議從庫(kù)設(shè)為read only,以防人為誤操作從庫(kù)數(shù)據(jù)。
  • 監(jiān)控主從延遲及狀態(tài),及時(shí)解決同步中斷或延遲問題。

總結(jié):

本文介紹了主從復(fù)制的原理及搭建過程,其實(shí)關(guān)于主從復(fù)制的內(nèi)容還有很多,需要不斷的學(xué)習(xí)。這里推薦大家使用GTID模式來搭建主從復(fù)制,關(guān)于后面分享的幾點(diǎn)經(jīng)驗(yàn),也是自己日常積累的,希望對(duì)你有所幫助。寫作不易,覺得還不錯(cuò)的話,請(qǐng)順手轉(zhuǎn)發(fā)分享下哦。

以上就是詳細(xì)分析MySQL主從復(fù)制的詳細(xì)內(nèi)容,更多關(guān)于MySQL主從復(fù)制的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 一步步教你在Navicat上如何停止正在運(yùn)行的MYSQL語(yǔ)句

    一步步教你在Navicat上如何停止正在運(yùn)行的MYSQL語(yǔ)句

    很多時(shí)候我們會(huì)提交一些耗時(shí)比較長(zhǎng)的sql,可能出現(xiàn)mysql服務(wù)器內(nèi)存或者CPU暴增,引起報(bào)警,甚至影響其他業(yè)務(wù),下面這篇文章主要給大家介紹了關(guān)于在Navicat上如何停止正在運(yùn)行的MYSQL語(yǔ)句的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • PHP連接MySql閃斷自動(dòng)重連的方法

    PHP連接MySql閃斷自動(dòng)重連的方法

    當(dāng)mysql連接閃斷時(shí),之后循環(huán)的執(zhí)行將會(huì)失敗。這篇文章主要介紹了PHP連接MySql閃斷自動(dòng)重連的方法,非常不錯(cuò),具有參考借鑒價(jià)值,感興趣的朋友一起學(xué)習(xí)吧
    2016-08-08
  • Mysql在Windows系統(tǒng)快速安裝部署方法(綠色免安裝版)

    Mysql在Windows系統(tǒng)快速安裝部署方法(綠色免安裝版)

    這篇文章主要介紹了Mysql在Windows系統(tǒng)快速安裝部署方法(綠色免安裝版),需要的朋友可以參考下
    2017-06-06
  • mysql中update和select結(jié)合使用方式

    mysql中update和select結(jié)合使用方式

    這篇文章主要介紹了mysql中update和select結(jié)合使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • MySQL無法創(chuàng)建外鍵的原因及解決方法

    MySQL無法創(chuàng)建外鍵的原因及解決方法

    這篇文章主要介紹了MySQL無法創(chuàng)建外鍵的原因及解決方法,然后在文中給大家及時(shí)了MySQL無法創(chuàng)建外鍵、查詢外鍵的屬性知識(shí),感興趣的朋友一起看看吧
    2017-10-10
  • mysql修改sql_mode報(bào)錯(cuò)的解決

    mysql修改sql_mode報(bào)錯(cuò)的解決

    今天在Navicat中運(yùn)行sql語(yǔ)句創(chuàng)建數(shù)據(jù)表出現(xiàn)了錯(cuò)誤Err 1067。本文主要介紹了mysql修改sql_mode報(bào)錯(cuò)的解決,感興趣的可以了解一下
    2021-09-09
  • MySQL索引查詢的具體使用

    MySQL索引查詢的具體使用

    本文主要介紹了MySQL索引查詢的具體使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • MySQL中一些常用的數(shù)據(jù)表操作語(yǔ)句筆記

    MySQL中一些常用的數(shù)據(jù)表操作語(yǔ)句筆記

    這篇文章主要介紹了MySQL中一些常用的數(shù)據(jù)表操作語(yǔ)句筆記,其中重點(diǎn)講解了刪除關(guān)聯(lián)表的方法,需要的朋友可以參考下
    2016-03-03
  • MySQL執(zhí)行狀態(tài)的查看與分析

    MySQL執(zhí)行狀態(tài)的查看與分析

    今天小編就為大家分享一篇關(guān)于MySQL執(zhí)行狀態(tài)的查看與分析,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • MySQL如何從數(shù)據(jù)庫(kù)中刪除表中所有數(shù)據(jù)

    MySQL如何從數(shù)據(jù)庫(kù)中刪除表中所有數(shù)據(jù)

    這篇文章主要介紹了MySQL如何從數(shù)據(jù)庫(kù)中刪除表中所有數(shù)據(jù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06

最新評(píng)論