mysql 3节点mgr集群部署

mysql 3节点mgr集群部署,版本8.4.6

rpm安装mysql

省略

重置节点(部署出错时),执行与主节点完全相同的重置流程

shell 复制代码
sudo systemctl stop mysqld
sudo rm -rf /data/mysql/*
sudo mkdir -p /data/mysql/data /data/mysql/log /data/mysql/tmp
sudo chown -R mysql:mysql /data/mysql/
sudo vim /etc/my.cnf # 先关闭MGR相关配置,初始化之后再打开
sudo mysqld --initialize-insecure --user=mysql --datadir=/data/mysql/data
sudo systemctl start mysqld

主节点操作

sql 复制代码
-- 设置root密码
ALTER USER 'root'@'localhost' IDENTIFIED BY 'Qwer@123';

-- 创建MGR恢复用户
DROP USER 'repl'@'%';
CREATE USER 'repl'@'%' IDENTIFIED BY 'Qwer@123';
CREATE USER 'repl'@'%' IDENTIFIED WITH mysql_native_password BY 'Qwer@123';

-- 授予所有权限
GRANT REPLICATION SLAVE, BACKUP_ADMIN, GROUP_REPLICATION_STREAM ON *.* TO 'repl'@'%';
FLUSH PRIVILEGES;

-- 初始化集群
SET GLOBAL group_replication_bootstrap_group=ON;
START GROUP_REPLICATION;
SET GLOBAL group_replication_bootstrap_group=OFF;

从节点操作

sql 复制代码
-- 关键步骤:告诉从节点用哪个用户去主节点那里克隆数据
CHANGE REPLICATION SOURCE TO SOURCE_USER='repl', SOURCE_PASSWORD='Qwer@123' FOR CHANNEL 'group_replication_recovery';
-- 启动加入流程
START GROUP_REPLICATION;

sql命令

sql 复制代码
-- 主节点查看集群状态
SELECT * FROM performance_schema.replication_group_members;
--查看插件是否生效
show plugins;

配置文件,以主节点为例

ini 复制代码
# /etc/my.cnf
[mysqld]
server_id=1
datadir=/data/mysql/data
socket=/data/mysql/mysql.sock
log_error=/data/mysql/log/mysqld.err
tmpdir=/data/mysql/tmp
bind-address=0.0.0.0
# 开启传统加密插件,新版本默认的加密插件需要ssl
mysql-native-password=on

# Binlog

log_bin=/data/mysql/log/mysql-bin
binlog_format=ROW
gtid_mode=ON
enforce_gtid_consistency=ON
log_replica_updates=ON

# InnoDB

innodb_buffer_pool_size=4G

# Group Replication (MGR)

plugin_load_add=group_replication.so
group_replication_group_name=qwe-asd-zxc
report_host = 10.123.123.20
group_replication_local_address=10.123.123.20:33061
group_replication_ip_allowlist=10.1.0.0/16
group_replication_group_seeds=10.123.123.20:33061,10.123.123.21:33061,10.123.123.22:33061
group_replication_start_on_boot=OFF
group_replication_single_primary_mode=ON
group_replication_enforce_update_everywhere_checks=OFF

[client]
socket=/data/mysql/mysql.sock
相关推荐
阿梦Anmory3 小时前
Ubuntu配置代理最详细教程
linux·运维·ubuntu
爬山算法3 小时前
Hibernate(87)如何在安全测试中使用Hibernate?
java·后端·hibernate
呉師傅4 小时前
【使用技巧】Adobe Photoshop 2024调整缩放与布局125%后出现点菜单项漂移问题的简单处理
运维·服务器·windows·adobe·电脑·photoshop
heartbeat..4 小时前
JVM 性能调优流程实战:从开发规范到生产应急排查
java·运维·jvm·性能优化·设计规范
WeiXiao_Hyy4 小时前
成为 Top 1% 的工程师
java·开发语言·javascript·经验分享·后端
苏渡苇4 小时前
优雅应对异常,从“try-catch堆砌”到“设计驱动”
java·后端·设计模式·学习方法·责任链模式
long3164 小时前
Aho-Corasick 模式搜索算法
java·数据结构·spring boot·后端·算法·排序算法
小Tomkk4 小时前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase
赌博羊4 小时前
ImportError: /lib/x86_64-linux-gnu/libc.so.6: version `GLIBC_2.32‘ not found
linux·运维·gnu
rannn_1114 小时前
【苍穹外卖|Day4】套餐页面开发(新增套餐、分页查询、删除套餐、修改套餐、起售停售)
java·spring boot·后端·学习