Linux环境下搭建 MySQL8 主从复制
生活随笔
收集整理的這篇文章主要介紹了
Linux环境下搭建 MySQL8 主从复制
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
文章目錄
- 1. 環(huán)境說明
- 2. 主從同步解析
- 3. MASTER 主節(jié)點配置
- 4. SLAVE 從節(jié)點配置
- 5. 配置同步某個庫或者表
1. 環(huán)境說明
準(zhǔn)備2臺虛擬機(jī),1主1從,分別安裝MySQL。安裝步驟這邊就不贅述了,之前的文章有完整的步驟:https://blog.csdn.net/qq_28834355/article/details/108396968
| 192.168.25.132 | 主 |
| 192.168.25.133 | 從 |
2. 主從同步解析
流程圖
流程解析說明
- 主從數(shù)據(jù)庫的版本必須一致
- 主節(jié)點必須啟用二進(jìn)制日志(bin-log),記錄任何修改數(shù)據(jù)庫數(shù)據(jù)的事件
- 從節(jié)點連接主節(jié)點,并請求主節(jié)點bin-log的事件
- 主節(jié)點檢查bin-log,與從節(jié)點請求的位置對比。如果不帶位置參數(shù),則返回所有bin-log信息(全量);如果有帶位置參數(shù),則從該位置開始傳輸bin-log(增量)
- 從節(jié)點將接收到的bin-log放入中繼日志(relay-log),并記錄同步的位置
- 從節(jié)點啟動啟動另一個線程,讀取并執(zhí)行relay-log的事件
3. MASTER 主節(jié)點配置
在兩個MySQL實例分別建一個test庫,用于主從同步測試
修改配置文件
vim /etc/my.cnf在 [mysqld] 部分加上如下配置:
#日志文件名稱 log-bin=master-bin #二進(jìn)制日志格式,有row、statement、mixed三中類型 binlog-format=ROW#各個服務(wù)器的ID,不能相同 server-id=1#同步的數(shù)據(jù)庫名稱 binlog-do-db=test創(chuàng)建用于同步的賬號
創(chuàng)建賬號 repl,密碼 123456
mysql>create user 'repl'@'%' identified WITH mysql_native_password by '123456'; mysql>grant replication slave on *.* to 'repl'@'%';刷新授權(quán)表信息
mysql>flush privileges;重啟數(shù)據(jù)庫服務(wù)
service mysql restart查看master信息(后面會用到)
mysql> show master status; +-------------------+----------+--------------+------------------+-------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set | +-------------------+----------+--------------+------------------+-------------------+ | master-bin.000002 | 156 | test | | | +-------------------+----------+--------------+------------------+-------------------+ 1 row in set (0.00 sec)4. SLAVE 從節(jié)點配置
修改配置文件
vim /etc/my.cnf在 [mysqld] 部分加上如下配置:
#日志文件名稱(跟MASTER一致就行) log-bin=master-bin#二進(jìn)制日志格式,有row、statement、mixed三中類型 binlog-format=ROW##各個服務(wù)器的ID,不能相同 server-id=2#中繼日志執(zhí)行之后,這些變化是否記入自己的bin-log。當(dāng)此SLAVE要作為另一個節(jié)點的MASTER,這個就必須打開 #log-slave-updates=true重啟數(shù)據(jù)庫服務(wù)
service mysql restart設(shè)置主節(jié)點參數(shù)
mysql> change master to master_host='192.168.25.132',master_user='repl',master_password='123456',master_port=3306,master_log_file='master-bin.000002',master_log_pos=156; Query OK, 0 rows affected, 2 warnings (0.00 sec)開啟主從同步
mysql> start slave; Query OK, 0 rows affected (0.00 sec)如果需要停止主從同步,執(zhí)行 stop slave;
查看狀態(tài)
mysql> show slave status\G;如果一切正常,應(yīng)該是如下圖所示,顯示兩個Yes
5. 配置同步某個庫或者表
有兩種方式,二選一
- 在主庫配置
- 在從庫配置
總結(jié)
以上是生活随笔為你收集整理的Linux环境下搭建 MySQL8 主从复制的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Redis5.0.8集群搭建与说明
- 下一篇: linux cmake编译源码,linu