前言:
在MySQL中,主從架構應該是最基礎、最常用的一種架構了。后續(xù)的讀寫分離、多活高可用架構等大多都依賴于主從復制。主從復制也是我們學習MySQL過程中必不可少的一部分,關于主從復制的文章有很多,筆者也來湊湊熱鬧,寫寫這方面的內容吧,同時分享下自己的經(jīng)驗和方法。
1.主從復制簡介及原理
主從復制(也稱 AB 復制)是指一臺服務器充當主數(shù)據(jù)庫服務器,另一臺或多臺服務器充當從數(shù)據(jù)庫服務器,主服務器中的數(shù)據(jù)自動復制到從服務器之中。對于多級復制,數(shù)據(jù)庫服務器既可充當主機,也可充當從機。MySQL默認采用異步復制方式。
主從復制的過程及原理可以總結如下:
2.基于二進制文件位置配置主從復制
基于二進制文件位置的主從復制又可以稱為傳統(tǒng)復制,即從服務器依賴于主服務器的binlog文件位置,當主庫發(fā)生數(shù)據(jù)變更時,binlog pos位點會增長,從庫會感應到變化來完成同步。
配置主從復制,我們首先要準備至少兩臺MySQL實例,一臺充當主服務器、一臺充當從服務器。由于主從復制依賴于binlog,所以主庫必須開啟binlog,且主從要配置不同的server_id,下面具體展示下配置過程:
2.1 確認主從庫配置參數(shù)
MySQL主從服務器建議有如下配置,可以先確認下,如果未配置,則需要修改配置文件然后重啟。
# 主庫參數(shù)配置 要有以下參數(shù) vim /etc/my.cnf [mysqld] log-bin = binlog //啟用二進制日志 server-id = 137 //服務器唯一ID,默認值是1,一般設置為IP地址的最后一段數(shù)字 binlog_format = row //bilog設置為row模式 防止復制出錯 # 從庫建議配置以下參數(shù) vim /etc/my.cnf [mysqld] relay-log = relay-bin server-id = 138
2.2 確定主庫二進制位置,創(chuàng)建同步賬號
若主從庫都是剛剛初始化完成,且主庫無操作時,從庫可不用同步主庫的數(shù)據(jù),直接確定主庫的binlog位置即可。
# 查看主庫binlog文件位置 show master status; # 主庫創(chuàng)建同步賬號 create user 'repl'@'%' identified by '123456'; grant replication slave on *.* to 'repl'@'%';
若主庫已經(jīng)運行了一段時間,有業(yè)務數(shù)據(jù)在,而從庫剛剛初始化完成,此時則需要備份主庫的數(shù)據(jù),然后導入從庫,使得主從數(shù)據(jù)一致。
# 主庫創(chuàng)建同步賬號 create user 'repl'@'%' identified by '123456'; grant replication slave on *.* to 'repl'@'%'; # 全備主庫數(shù)據(jù) mysqldump -uroot -pxxxx -A -R -E --single-transaction --master-data=2 > all_db.sql # 從庫端恢復 mysql -uroot -pxxxx all_db.sql # 從備份文件中可以找到主庫的binlog位置
2.3 進入從庫,開啟主從復制
找到主庫二進制文件位置且完成主從數(shù)據(jù)一致后,我們就可以正式開啟主從復制了。
# 進入從庫MySQL命令行 執(zhí)行change master語句連接主庫 # 二進制文件名及pos位置由上面步驟獲得 CHANGE MASTER TO MASTER_HOST='MySQL主服務器IP地址', MASTER_PORT=3306, MASTER_USER='repl', MASTER_PASSWORD='123456', MASTER_LOG_FILE='binlog.000002', MASTER_LOG_POS=154; # 開啟主從復制 并堅持狀態(tài) start slave; show slave status \G //查看slave狀態(tài) 確保Slave_IO_Running: Yes Slave_SQL_Running: Yes
3.基于GTID的主從復制
GTID是MySQL 5.6的新特性,其全稱是Global Transaction Identifier,可簡化MySQL的主從切換以及Failover。GTID用于在binlog中唯一標識一個事務。當事務提交時,MySQL Server在寫binlog的時候,會先寫一個特殊的Binlog Event,類型為GTID_Event,指定下一個事務的GTID,然后再寫事務的Binlog。
在基于GTID的復制中,首先從服務器會告訴主服務器已經(jīng)在從服務器執(zhí)行完了哪些事務的GTID值,然后主庫會有把所有沒有在從庫上執(zhí)行的事務,發(fā)送到從庫上進行執(zhí)行,并且使用GTID的復制可以保證同一個事務只在指定的從庫上執(zhí)行一次,這樣可以避免由于偏移量的問題造成數(shù)據(jù)不一致。也就是說,無論是級聯(lián)情況,還是一主多從的情況,都可以通過GTID自動找位置,而無需像之前那樣通過File_name和File_position找主庫binlog位置了。
基于GTID的主從復制與上面基于二進制文件位置的主從復制搭建步驟類似,同樣簡單展示下搭建過程:
3.1 確認主從庫配置,開啟GTID
# 主庫參數(shù)配置 要有以下參數(shù) vim /etc/my.cnf [mysqld] server-id = 137 log-bin = binlog binlog_format = row gtid-mode = ON //開啟gtid模式 enforce-gtid-consistency = ON //強制gtid一致性,用于保證啟動gitd后事務的安全 # 從庫建議配置以下參數(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)建同步賬號,保持主從庫數(shù)據(jù)一致
若主庫剛初始化完成或者主庫端保留有全部二進制文件,則從庫無需手動同步數(shù)據(jù)。否則需要手動同步數(shù)據(jù)使得主從一致。
# 主庫創(chuàng)建同步賬號 create user 'repl'@'%' identified by '123456'; grant replication slave on *.* to 'repl'@'%'; # 若主庫剛初始化或保留有完整二進制文件 則無需執(zhí)行下面步驟 # 全備主庫數(shù)據(jù) mysqldump -uroot -pxxxx -A -R -E --single-transaction > all_db.sql # 從庫端恢復 mysql -uroot -pxxxx all_db.sql
3.3 進入從庫,開啟主從復制
# 進入從庫MySQL命令行 執(zhí)行change master語句連接主庫 CHANGE MASTER TO MASTER_HOST='MySQL主服務器IP地址', MASTER_PORT=3306, MASTER_USER='repl', MASTER_PASSWORD='123456', MASTER_AUTO_POSITION = 1; # 開啟主從復制 并堅持狀態(tài) start slave; show slave status \G
4.一些經(jīng)驗及建議
在日常學習及工作過程中,主從復制方面也積累了一些經(jīng)驗,下面簡單分享幾點,希望各位少踩坑。
總結:
本文介紹了主從復制的原理及搭建過程,其實關于主從復制的內容還有很多,需要不斷的學習。這里推薦大家使用GTID模式來搭建主從復制,關于后面分享的幾點經(jīng)驗,也是自己日常積累的,希望對你有所幫助。寫作不易,覺得還不錯的話,請順手轉發(fā)分享下哦。
以上就是詳細分析MySQL主從復制的詳細內容,更多關于MySQL主從復制的資料請關注腳本之家其它相關文章!
標簽:合肥 鷹潭 日照 北京 臺灣 阜新 貴州 鎮(zhèn)江
巨人網(wǎng)絡通訊聲明:本文標題《詳細分析MySQL主從復制》,本文關鍵詞 詳細,分析,MySQL,主從,復制,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。