MySQL主從復(fù)制原理解析與最佳實(shí)踐過(guò)程
一、主從復(fù)制
1、復(fù)制的基本原理
主要涉及三個(gè)線程:binlog 線程、I/O 線程和 SQL 線程
- binlog 線程 :負(fù)責(zé)將主服務(wù)器上的數(shù)據(jù)更改寫入二進(jìn)制日志(Binary log)中
- I/O 線程 :負(fù)責(zé)在主服務(wù)器上讀取二進(jìn)制日志,并寫入從服務(wù)器的中繼日志(Relay log)
- SQL 線程 :負(fù)責(zé)讀取中繼日志,解析出主服務(wù)器已經(jīng)執(zhí)行的數(shù)據(jù)更改并在從服務(wù)器中執(zhí)行
2、復(fù)制的基本原則
- 每個(gè)master可以有多個(gè)slave
- 每個(gè)slave只有一個(gè)master
- 每個(gè)slave只能有一個(gè)唯一的服務(wù)器ID
二、最佳實(shí)踐
- 本次實(shí)踐采用一主一從復(fù)制,一主為windows,一從為虛擬機(jī)Centos7,MySQL版本5.7保持一致
1、ping測(cè)試
- 虛擬機(jī)采用NAT連接,物理機(jī)關(guān)閉防火墻
- 雙方互相進(jìn)行ping測(cè)試,記錄主從各自服務(wù)器的IP地址
2、主服務(wù)器配置
- 修改my.ini文件,默認(rèn)在C:\ProgramData\MySQL\MySQL Server 5.7
主服務(wù)器唯一ID
[mysqld] server-id=1
啟用二進(jìn)制文件
log-bin="mysqlbin"
關(guān)閉只讀
#可選 read-only=0
忽略備份
#可選 binlog-ignore-db=mysql
設(shè)置備份
#可選 binlog-do-db=test
3、從服務(wù)器配置
從服務(wù)器唯一ID
[mysqld] server-id=2
啟用二進(jìn)制文件
log-bin="mysqlbin"
4、主服務(wù)器設(shè)置
- CMD打開MySQL會(huì)話
創(chuàng)建用戶
#可選 CREATE USER 'test'@'從服務(wù)器IP' IDENTIFIED BY 'test'; #CREATE USER 'test'@'192.168.189.129' IDENTIFIED BY 'test';
賦予權(quán)限
grant replication slave on *.* to 'test'@'192.168.189.129' identified by 'test';
刷新權(quán)限
flush privileges;
查看master狀態(tài)
show master status\G;
記錄二進(jìn)制文件名和位置
+------------------+----------+--------------+------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | +------------------+----------+--------------+------------------+ | mysql-bin.000003 | 73 | test | manual,mysql | +------------------+----------+--------------+------------------+
5、從服務(wù)器設(shè)置
- CMD打開MySQL會(huì)話
執(zhí)行同步SQL
#主服務(wù)器IP、用戶名、密碼、二進(jìn)制文件名、位置 change master to master_host='192.168.189.1', master_user='test', master_password='test', master_log_file='mysql-bin.000003',master_log_pos=73;
開啟slave
start slave;
查看slave狀態(tài)
mysql> show slave status\G; *************************** 1. row *************************** Slave_IO_State: Waiting for master to send event Master_Host: 182.92.172.80 Master_User: rep1 Master_Port: 3306 Connect_Retry: 60 Master_Log_File: mysql-bin.000013 Read_Master_Log_Pos: 11662 Relay_Log_File: mysqld-relay-bin.000022 Relay_Log_Pos: 11765 Relay_Master_Log_File: mysql-bin.000013 Slave_IO_Running: Yes Slave_SQL_Running: Yes Replicate_Do_DB: Replicate_Ignore_DB:
- 當(dāng)Slave_IO_Running和Slave_SQL_Running都為YES的時(shí)候就表示主從同步設(shè)置成功了。
- 如果不成功,先關(guān)閉slave,重新進(jìn)行從服務(wù)器設(shè)置
6、主從測(cè)試
- 在主服務(wù)器備份的數(shù)據(jù)庫(kù)(本次為test)中插入一條數(shù)據(jù),在從服務(wù)器中驗(yàn)證是否復(fù)制成功(成功)
- 在主服務(wù)器中新建一個(gè)數(shù)據(jù)庫(kù),插入多條數(shù)據(jù),在從服務(wù)器中驗(yàn)證是否復(fù)制成功(備份指定數(shù)據(jù)庫(kù),復(fù)制失敗)
- 關(guān)閉slave(mysql>stop slave;),然后再修改master,看slave是否也相應(yīng)修改(停止slave后,master的修改不會(huì)同步到slave),就可以完成主從復(fù)制功能的驗(yàn)證了
7、關(guān)閉slave
stop slave;
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
C#實(shí)現(xiàn)MySQL命令行備份和恢復(fù)
MySQL數(shù)據(jù)庫(kù)的備份有很多工具可以使用,今天介紹一下使用C#調(diào)用MYSQL的mysqldump命令完成MySQL數(shù)據(jù)庫(kù)的備份與恢復(fù)2018-03-03MySQL數(shù)據(jù)庫(kù)操作常用命令小結(jié)
這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)操作常用命令小結(jié),例如創(chuàng)建數(shù)據(jù)庫(kù)、使用數(shù)據(jù)庫(kù)、查看數(shù)據(jù)庫(kù)、數(shù)據(jù)庫(kù)編碼操作等命令講解,需要的朋友可以參考下2014-12-12解決Mysql5.7.17在windows下安裝啟動(dòng)時(shí)提示不成功問(wèn)題
這篇文章主要介紹了解決Mysql5.7.17在windows下安裝啟動(dòng)時(shí)提示不成功問(wèn)題,需要的朋友可以參考下2017-03-03MySQL數(shù)據(jù)庫(kù)表的合并與分區(qū)實(shí)現(xiàn)介紹
今天我們來(lái)聊聊處理大數(shù)據(jù)時(shí)Mysql的存儲(chǔ)優(yōu)化。當(dāng)數(shù)據(jù)達(dá)到一定量時(shí),一般的存儲(chǔ)方式就無(wú)法解決高并發(fā)問(wèn)題了。最直接的MySQL優(yōu)化就是分區(qū)分表,以下是我個(gè)人對(duì)分區(qū)分表的筆記2022-09-09PHP MYSQL注入攻擊需要預(yù)防7個(gè)要點(diǎn)
這篇文章主要介紹了PHP MYSQL開發(fā)中,對(duì)于注入攻擊需要預(yù)防的7個(gè)要點(diǎn),大家需要注意了2013-11-11mysql數(shù)據(jù)庫(kù)連接失敗常見(jiàn)問(wèn)題小結(jié)
你有沒(méi)有碰到過(guò)mysql數(shù)據(jù)庫(kù)連接不上的問(wèn)題呢?很多的小伙伴表示,經(jīng)常會(huì)時(shí)不時(shí)的出現(xiàn)這些問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于mysql數(shù)據(jù)庫(kù)連接失敗常見(jiàn)問(wèn)題的相關(guān)資料,需要的朋友可以參考下2023-06-06