日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

Linux环境下搭建 MySQL8 主从复制

發(fā)布時間:2025/3/19 数据库 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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. 配置同步某個庫或者表

有兩種方式,二選一

  • 在主庫配置
#同步指定的庫 binlog-do-db=xxxx #忽略同步某個庫 binlog-ignore-db=xxxx
  • 在從庫配置
#設(shè)定需要復(fù)制的數(shù)據(jù)庫 replicate-do-db= #設(shè)定需要忽略的復(fù)制數(shù)據(jù)庫 replicate-ignore-db= #設(shè)定需要復(fù)制的表 replicate-do-table= #設(shè)定需要忽略的復(fù)制表 replicate-ignore-table= #同replication-do-table功能一樣,但是可以通配符 replicate-wild-do-table= #同replication-ignore-table功能一樣,但是可以加通配符 replicate-wild-ignore-table=

總結(jié)

以上是生活随笔為你收集整理的Linux环境下搭建 MySQL8 主从复制的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。