MySQL 8.0.42創建MGR集群

MySQL 8.0.42創建MGR集群

概述

關于MySQL MGR集群的介紹就不在這里做詳細的介紹了,大家可以自己到官網上查看閱讀。在這里主要是實際操作方面的內容

總體結構設計如下圖
在這里插入圖片描述

服務器節點信息

序號角色IP地址數據庫端口MGR端口
1主節點192.168.56.104330910061
2從節點192.168.56.105330910061
3從節點192.168.56.106330910061

my.cnf配置

節點1

[mysqld]
##basic settings###
server-id=104
port = 3309
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
skip-name-resolve
max_connections=1000
max_user_connections=800
max_allowed_packet=512M
max_connect_errors=100000
datadir = /usr/local/mysql/data
socket = /usr/local/mysql/data/mysql.sock
pid_file = /usr/local/mysql/data/mysql.pid
transaction_isolation = READ-COMMITTED
lower_case_table_names=1
default_time_zone =+8:00
open_files_limit=65535
log_timestamps=system
wait_timeout=900
interactive_timeout=900##innodb setting##
innodb_buffer_pool_size = 256M
innodb_buffer_pool_instances = 1
innodb_io_capacity=2000
innodb_flush_method=O_DIRECT
innodb_flush_neighbors=0
innodb_flush_log_at_trx_commit = 1
innodb_print_all_deadlocks = 1
innodb_online_alter_log_max_size=128M
innodb_lock_wait_timeout=10
innodb_file_per_table=ON
innodb_doublewrite=ON##log settings##
log-error = /usr/local/mysql/data/error.log
log-bin = /usr/local/mysql/data/mysql_bin.log
slow_query_log = 1
slow_query_log_file = /usr/local/mysql/data/mysql_slow_query.log
long_query_time = 10##replication settings##
gtid-mode=on
enforce-gtid-consistency=true
master-info-repository=TABLE
relay-log-info-repository=TABLE
sync-master-info=1000
relay_log_recovery = 1
relay-log=/usr/local/mysql/data/relay-bin#binlog
log_bin=/usr/local/mysql/data/binlog
#expire_logs_days=10  #MySQL 5.7版本
binlog_expire_logs_seconds = 604800 # 保留7天
max_binlog_cache_size=200M
sync_binlog=1##MGR settings
binlog_checksum = NONE
log_replica_updates = ON
binlog_format=rowplugin_load_add='group_replication.so'
#transaction_write_set_extraction ='XXHASH64'
#loose-group_replication_group_name = 'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa'
#loose-group_replication_start_on_boot = off
#loose-group_replication_local_address = '192.168.56.104:10061'
#loose-group_replication_group_seeds ='192.168.56.104:10061,192.168.56.105:10061,192.168.56.106:10061'
#loose-group_replication_bootstrap_group = off
#loose-group_replication_ip_whitelist = '192.168.56.104/24,192.168.56.105/24,192.168.56.106/24'
#loose-group_replication_member_weight=50
#loose-group_replication_single_primary_mode=ON
#loose-group_replication_enforce_update_everywhere_checks=OFF  ###單主模式關閉,多主模式開啟[client]
port = 3309
socket = /usr/local/mysql/data/mysql.sock

節點2

[mysqld]
##basic settings###
server-id=105
port = 3309
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
skip-name-resolve
max_connections=1000
max_user_connections=800
max_allowed_packet=512M
max_connect_errors=100000
datadir = /usr/local/mysql/data
socket = /usr/local/mysql/data/mysql.sock
pid_file = /usr/local/mysql/data/mysql.pid
transaction_isolation = READ-COMMITTED
lower_case_table_names=1
default_time_zone =+8:00
open_files_limit=65535
log_timestamps=system
wait_timeout=900
interactive_timeout=900##innodb setting##
innodb_buffer_pool_size = 256M
innodb_buffer_pool_instances = 1
innodb_io_capacity=2000
innodb_flush_method=O_DIRECT
innodb_flush_neighbors=0
innodb_flush_log_at_trx_commit = 1
innodb_print_all_deadlocks = 1
innodb_online_alter_log_max_size=128M
innodb_lock_wait_timeout=10
innodb_file_per_table=ON
innodb_doublewrite=ON##log settings##
log-error = /usr/local/mysql/data/error.log
log-bin = /usr/local/mysql/data/mysql_bin.log
slow_query_log = 1
slow_query_log_file = /usr/local/mysql/data/mysql_slow_query.log
long_query_time = 10##replication settings##
gtid-mode=on
enforce-gtid-consistency=true
master-info-repository=TABLE
relay-log-info-repository=TABLE
sync-master-info=1000
relay_log_recovery = 1
relay-log=/usr/local/mysql/data/relay-bin#binlog
log_bin=/usr/local/mysql/data/binlog
#expire_logs_days=10  #MySQL 5.7版本
binlog_expire_logs_seconds = 604800 # 保留7天
max_binlog_cache_size=200M
sync_binlog=1##MGR settings
binlog_checksum = NONE
log_replica_updates = ON
binlog_format=rowplugin_load_add='group_replication.so'
#transaction_write_set_extraction ='XXHASH64'
#loose-group_replication_group_name = 'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa'
#loose-group_replication_start_on_boot = off
#loose-group_replication_local_address = '192.168.56.105:10061'
#loose-group_replication_group_seeds ='192.168.56.104:10061,192.168.56.105:10061,192.168.56.106:10061'
#loose-group_replication_bootstrap_group = off
#loose-group_replication_ip_whitelist = '192.168.56.104/24,192.168.56.105/24,192.168.56.106/24'
#loose-group_replication_member_weight=50
#loose-group_replication_single_primary_mode=ON
#loose-group_replication_enforce_update_everywhere_checks=OFF  ###單主模式關閉,多主模式開啟[client]
port = 3309
socket = /usr/local/mysql/data/mysql.sock

節點3

[mysqld]
##basic settings###
server-id=106
port = 3309
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
skip-name-resolve
max_connections=1000
max_user_connections=800
max_allowed_packet=512M
max_connect_errors=100000
datadir = /usr/local/mysql/data
socket = /usr/local/mysql/data/mysql.sock
pid_file = /usr/local/mysql/data/mysql.pid
transaction_isolation = READ-COMMITTED
lower_case_table_names=1
default_time_zone =+8:00
open_files_limit=65535
log_timestamps=system
wait_timeout=900
interactive_timeout=900##innodb setting##
innodb_buffer_pool_size = 256M
innodb_buffer_pool_instances = 1
innodb_io_capacity=2000
innodb_flush_method=O_DIRECT
innodb_flush_neighbors=0
innodb_flush_log_at_trx_commit = 1
innodb_print_all_deadlocks = 1
innodb_online_alter_log_max_size=128M
innodb_lock_wait_timeout=10
innodb_file_per_table=ON
innodb_doublewrite=ON##log settings##
log-error = /usr/local/mysql/data/error.log
log-bin = /usr/local/mysql/data/mysql_bin.log
slow_query_log = 1
slow_query_log_file = /usr/local/mysql/data/mysql_slow_query.log
long_query_time = 10##replication settings##
gtid-mode=on
enforce-gtid-consistency=true
master-info-repository=TABLE
relay-log-info-repository=TABLE
sync-master-info=1000
relay_log_recovery = 1
relay-log=/usr/local/mysql/data/relay-bin#binlog
log_bin=/usr/local/mysql/data/binlog
#expire_logs_days=10  #MySQL 5.7版本
binlog_expire_logs_seconds = 604800 # 保留7天
max_binlog_cache_size=200M
sync_binlog=1##MGR settings
binlog_checksum = NONE
log_replica_updates = ON
binlog_format=rowplugin_load_add='group_replication.so'
#transaction_write_set_extraction ='XXHASH64'
#loose-group_replication_group_name = 'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa'
#loose-group_replication_start_on_boot = off
#loose-group_replication_local_address = '192.168.56.106:10061'
#loose-group_replication_group_seeds ='192.168.56.104:10061,192.168.56.105:10061,192.168.56.106:10061'
#loose-group_replication_bootstrap_group = off
#loose-group_replication_ip_whitelist = '192.168.56.104/24,192.168.56.105/24,192.168.56.106/24'
#loose-group_replication_member_weight=50
#loose-group_replication_single_primary_mode=ON
#loose-group_replication_enforce_update_everywhere_checks=OFF  ###單主模式關閉,多主模式開啟[client]
port = 3309
socket = /usr/local/mysql/data/mysql.sock

三個節點的配置參數只是server-id和loose-group_replication_local_address不一樣。在初始化的時候先注釋掉mgr相關的參數,否則會提示ERROR,待初始化完成之后在取消注釋

初始化數據庫

所有節點

# 初始化數據目錄
/usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf --initialize --user=mysql --basedir=/usr/local/mysql # 生成的臨時密碼會顯示在終端,務必記錄!
cat /usr/local/mysql/data/error.log # 啟動關閉數據庫
/usr/local/mysql/bin/mysqld_safe --defaults-file=/etc/my.cnf &
/usr/local/mysql/bin/mysqladmin -uroot -p123456 --socket=/usr/local/mysql/data/mysql.sock shutdown &# 修改初始密碼
/usr/local/mysql/bin/mysql -uroot -p 
alter user 'root'@'localhost' identified WITH mysql_native_password by '123456';
flush privileges;

配置MGR

節點1
#創建 MGR 同步用戶

SET SQL_LOG_BIN=0;
CREATE USER 'rpl_user'@'%' IDENTIFIED WITH mysql_native_password BY 'rpl_pass';
GRANT REPLICATION SLAVE ON *.* TO rpl_user@'%';
GRANT BACKUP_ADMIN ON *.* TO rpl_user@'%';
FLUSH PRIVILEGES;
SET SQL_LOG_BIN=1;
select host,user,plugin from mysql.user;reset master;
change master tomaster_user='rpl_user',master_password='rpl_pass'for channel 'group_replication_recovery';

#查看確認 MGR 組件

#install plugin group_replication soname 'group_replication.so';
show plugins;

#啟動MGR復制組

set global group_replication_bootstrap_group=on;
start group_replication;
set global group_replication_bootstrap_group=off;select * from performance_schema.replication_group_members;###查看讀寫屬性
select @@read_only, @@super_read_only;

節點2
#創建 MGR 同步用戶

SET SQL_LOG_BIN=0;
CREATE USER rpl_user@'%' IDENTIFIED WITH mysql_native_password BY 'rpl_pass';
GRANT REPLICATION SLAVE ON *.* TO rpl_user@'%';
GRANT BACKUP_ADMIN ON *.* TO rpl_user@'%';
FLUSH PRIVILEGES;
SET SQL_LOG_BIN=1;
select host,user,plugin from mysql.user;reset master;
change master tomaster_user='rpl_user',master_password='rpl_pass'for channel 'group_replication_recovery';###啟動 MGR 復制組
start group_replication;select * from performance_schema.replication_group_members;###查看讀寫屬性
select @@read_only, @@super_read_only;

節點3
#創建 MGR 同步用戶

SET SQL_LOG_BIN=0;
CREATE USER rpl_user@'%' IDENTIFIED WITH mysql_native_password BY 'rpl_pass';
GRANT REPLICATION SLAVE ON *.* TO rpl_user@'%';
GRANT BACKUP_ADMIN ON *.* TO rpl_user@'%';
FLUSH PRIVILEGES;
SET SQL_LOG_BIN=1;
select host,user,plugin from mysql.user;reset master;
change master tomaster_user='rpl_user',master_password='rpl_pass'for channel 'group_replication_recovery';###啟動 MGR 復制組
start group_replication;select * from performance_schema.replication_group_members;###查看讀寫屬性
select @@read_only, @@super_read_only;

結果

mysql> select * from performance_schema.replication_group_members;
+---------------------------+--------------------------------------+-------------+-------------+--------------+-------------+----------------+----------------------------+
| CHANNEL_NAME              | MEMBER_ID                            | MEMBER_HOST | MEMBER_PORT | MEMBER_STATE | MEMBER_ROLE | MEMBER_VERSION | MEMBER_COMMUNICATION_STACK |
+---------------------------+--------------------------------------+-------------+-------------+--------------+-------------+----------------+----------------------------+
| group_replication_applier | 62f03723-6ade-11f0-8bc8-080027859595 | mgrser1     |        3309 | ONLINE       | PRIMARY     | 8.0.42         | XCom                       |
| group_replication_applier | 6afd9b46-6adf-11f0-88b8-080027238cc1 | mgrser2     |        3309 | ONLINE       | SECONDARY   | 8.0.42         | XCom                       |
| group_replication_applier | db344a82-6adf-11f0-ae5d-0800275e0275 | mgrser3     |        3309 | ONLINE       | SECONDARY   | 8.0.42         | XCom                       |
+---------------------------+--------------------------------------+-------------+-------------+--------------+-------------+----------------+----------------------------+
3 rows in set (0.00 sec)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/91042.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/91042.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/91042.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

《Go Web編程實戰派--從入門到精通》的隨筆筆記

第二章 Go Web 開發基礎2.1第一個Go Web 程序package mainimport ("fmt""net/http" )func hello(w http.ResponseWriter, r *http.Request) {fmt.Fprintf(w, "Hello World") } func main() {server : &http.Server{Addr: "0.0.0.0:80&q…

MySQL在Linux環境下的性能調優

📊 MySQL性能基準測試:知己知彼建立性能基線的關鍵指標# 核心性能指標監控腳本 #!/bin/bash echo " MySQL Performance Baseline " mysql -e "SHOW GLOBAL STATUS LIKE Questions;" mysql -e "SHOW GLOBAL STATUS LIKE Uptime;…

PyQt事件處理機制深度指南:超越信號與槽的底層掌控

—— 5大核心策略實戰案例,解鎖GUI交互的底層密碼 🔍 事件與信號槽的本質差異維度事件處理機制信號與槽機制抽象層級操作系統消息的原始封裝對事件的高級封裝應用場景控件行為定制/底層交互常規業務邏輯綁定執行順序先于信號槽觸發在事件處理完成后觸發性…

10_opencv_分離顏色通道、多通道圖像混合

split() 通道分離 void cv::split(const Mat & src,Mat * mvbegin ) merge() 通道合并 void cv::merge(InputArrayOfArrays mv,OutputArray dst ) Mat::at()方法 Mat::at()方法返回一個引用到指定的數組元素。 注意是引用,相當于兩者等價,也就是…

Kotlin的datetime庫

kotlinx 是一組不是 Kotlin 標準庫一部分,但非常實用的擴展項目集合。其中,kotlinx-datetime 是一個跨平臺的 Kotlin 時間日期處理庫。 如何在項目中使用該庫 Gradle 項目中 在 repositories 塊中添加 Maven Central 倉庫: repositories {…

基于模型蒸餾的大模型文案生成最佳實踐

背景 大語言模型在生成高質量文案方面表現優異,然而其巨大的計算資源消耗和存儲需求,使得實際應用尤其是在資源受限場景中的應用充滿挑戰。企業在尋求高效的文案生成時,常常面臨著在性能和資源之間權衡的困境。在這種背景下,模型…

調用通義千問大模型實現流式對話

前言 我使用的是硅基流動中通義千問免費的大模型:我的技術棧使用的 Next14.2 全棧框架。 代碼結構 需要使用的庫: npm i ai openai目錄結構: 基礎測試頁面 test-openai/page.tsx: use client;import { useChat } from ai/react;ex…

如何搭建Linux環境下的flink本地集群

第一步,搭建Linux環境 這里我使用的是 WSL2 安裝前,先用管理員打開終端,執行以下三條命令,目的是開啟安裝 WSL2所需要的環境 //開啟適用于windows的Linux子系統 dism.exe /online /enable-feature /featurename:Microsoft-Wind…

算法:鏈表part02:24. 兩兩交換鏈表中的節點 + 19. 刪除鏈表的倒數第 N 個結點 + 面試題 02.07. 鏈表相交

24. 兩兩交換鏈表中的節點題目:https://leetcode.cn/problems/swap-nodes-in-pairs/description/ 講解:https://programmercarl.com/0024.%E4%B8%A4%E4%B8%A4%E4%BA%A4%E6%8D%A2%E9%93%BE%E8%A1%A8%E4%B8%AD%E7%9A%84%E8%8A%82%E7%82%B9.html 復習可以先…

【Linux學習】(11)進程的概念

前言在上一章我們知道了什么是進程,并簡單了解了PCB。 本文我們將繼續深入學習進程概念相關知識點: 學習進程狀態,學會創建進程,掌握僵尸進程和孤兒進程,及其形成原因和危害了解進程調度,Linux進程優先級&a…

UniappDay04

1.登錄模塊-小程序快捷登錄定義接口,封裝 import { http } from /utils/httptype loginParams {code: stringencryptedData: stringiv: string } export const postLoginWxMinAPI (data: loginParams) > {return http({method: POST,url: /login/wxMin,data,})…

NPM/Yarn完全指南:前端開發的“基石“與“加速器“

開篇:當你第一次運行npm install時... "這node_modules文件夾怎么比我的項目代碼還大100倍?!" —— 每個前端新手第一次看到node_modules時的反應都出奇地一致。別擔心,今天我要帶你徹底搞懂這個讓項目"膨脹"的"罪魁禍首",以及如何用NPM/Y…

vue頁面自定義滾動條

效果圖實現思路 固定整個灰色滾動條的長度計算可滾動區域占整個可視視圖的比例&#xff0c;來確定橙色塊的長度監聽頁面滾動&#xff0c;計算橙色塊向右偏移距離 主要代碼 template&#xff1a; <div v-show"showBar" ref"barRef" class"scrollbar…

企業級JWT驗證最佳方案:StringUtils.hasText()

在企業級Java開發中&#xff0c;判斷JWT令牌是否有效的最全面且常用的方式是結合以下兩種方法&#xff1a; ? 推薦方案&#xff1a;StringUtils.hasText(jwt)&#xff08;Spring框架&#xff09; import org.springframework.util.StringUtils;if (!StringUtils.hasText(jwt))…

靈動畫布:快手可靈 AI 推出的多人協作 AI 創意工作臺

靈動畫布&#xff1a;快手可靈 AI 推出的多人協作 AI 創意工作臺 來源&#xff1a;Poixe AI 一、什么是靈動畫布 靈動畫布是快手旗下可靈 AI 于 2025 世界人工智能大會期間發布的全新創意工作臺功能。該功能集無限可視化畫布空間、多人實時協作及 AI 智能輔助于一體&#xf…

【Linux篇】進程間通信:進程IPC

目錄 共享內存空間 共享內存是在用戶空間還是內核空間&#xff1f;——用戶空間 共享內存的生命周期 如何使用共享內存 共享內存的權限 共享內存是進程間通信中&#xff0c;速度最快的方式&#xff1a; 共享內存的缺點&#xff1a; 進程間通信標準&#xff1a; system …

Kubernetes 存儲入門

目錄 Volume 的概念 Volume 的類型 通過 emptyDir 共享數據 編寫 emptyDir 的 Deployment 文件 部署該 Deployment 查看部署結果 登錄 Pod 中的第一個容器 登錄 Pod 中的第二個容器查看 /mnt 下的文件 刪除此 Pod 使用 HostPath 掛載宿主機文件 編寫 Deployment 文件…

深入理解Redission釋放鎖過程

lock.unlock();調用unlock方法&#xff0c;往下追Override public void unlock() {try {// 1. 執行異步解鎖操作并同步等待結果// - 獲取當前線程ID作為鎖持有者標識// - unlockAsync()觸發Lua腳本執行實際解鎖// - get()方法阻塞直到異步操作完成get(unlockAsync(Thread.curre…

四、計算機組成原理——第4章:指令系統

目錄 4.1指令系統 4.1.1指令集體系結構 4.1.2指令的基本格式 1.零地址指令 2.一地址指令 3.二地址指令 4.三地址指令 5.四地址指令 4.1.3定長操作碼指令格式 4.1.4擴展操作碼指令格式 4.1.5指令的操作類型 1.數據傳送 2.算術和邏輯運算 3.移位操作 4.轉移操作 …

RAG面試內容整理-檢索器與生成器的解耦架構

在RAG系統中,檢索器(Retriever)與生成器(Generator)的解耦架構是實現靈活高效的關鍵設計。所謂解耦,即將檢索相關文檔和生成答案兩個步驟分開,由不同的模塊或模型負責。這種架構帶來的直接好處是模塊獨立優化:我們可以針對檢索任務微調或更換檢索模型,而不必影響生成模…