MySQL 主从读写分离实现方案(一)—MariaDB MaxScale实现mysql8读写分离

news/2025/2/12 15:40:36/

一:MaxScale 是干什么的??

MaxScale是maridb开发的一个mysql数据中间件,其配置简单,能够实现读写分离,并且可以根据主从状态实现写库的自动切换,对多个从服务器能实现负载均衡。

img

二:MaxScale 实验环境部署

前提条件完成Mysql主从同步

中间件192.168.1.15MaxScale 24.02.4-1
主服务器192.168.1.10mysql 8.0.40
从服务器192.168.1.11mysql 8.0.40
从服务器192.168.1.12mysql 8.0.40

192.168.1.15(MaxScale)

从官方网站获取shell脚本,用于实现MariaDB包存储库的访问

[root@rocky ~]# curl -LsS https://r.mariadb.com/downloads/mariadb_repo_setup | sudo bash

查找与 MaxScale 相关的软件包

[root@rocky ~]# dnf list |grep -i maxscale

[root@rocky ~]# yum install maxscale -y

在/etc/maxscale.cnf.d新建一个配置my.cnf或者直接修改/etc/maxscale.cnf文件

[root@rocky ~]# cd /etc/maxscale.cnf.d/

[root@rocky maxscale.cnf.d]# vim my.cnf

[maxscale]
threads=auto

[dbserv1]
type=server
address=192.168.1.10
port=3306
protocol=MariaDBBackend

[dbserv2]
type=server
address=192.168.1.11
port=3306
protocol=MariaDBBackend

[dbserv3]
type=server
address=192.168.1.12
port=3306
protocol=MariaDBBackend

[MySQL-Monitor]
type=monitor
module=mariadbmon
servers=dbserv1, dbserv2, dbserv3
user=maxscale_monitor
password=Admin@123456
monitor_interval=2s

[Read-Write-Service]
type=service
router=readwritesplit
servers=dbserv1,dbserv2,dbserv3
user=maxscale_route
password=Admin@123456
enable_root_user=true

[Read-Write-Listener]
type=listener
service=Read-Write-Service
protocol=MariaDBClient
address=0.0.0.0
port=3306

192.168.1.10(master)

在 master中为 MaxScale 创建两个用户,用于监控模块和路由模块,已经实现主从复制的前提下,主库创建的用户,能同步到从库上

1.创建监控用户

--创建用户
mysql> create user 'maxscale_monitor'@'192.168.1.%' identified with mysql_native_password by 'Admin@123456';

--用户授权 “同步复制”、“同步复制状态”
mysql> grant replication slave, replication client on *.* to maxscale_monitor@'192.168.1.%';

2.创建路由用户

--创建用户
mysql>create user 'maxscale_route'@'192.168.1.%' identified with mysql_native_password by 'Admin@123456';
--用户授权
mysql>GRANT SHOW DATABASES ON *.* TO maxscale_route@'192.168.1.%';
mysql>GRANT SELECT ON mysql.user TO maxscale_route@'192.168.1.%';
mysql>GRANT SELECT ON mysql.db TO maxscale_route@'192.168.1.%';
mysql>GRANT SELECT ON mysql.tables_priv TO maxscale_route@'192.168.1.%';
mysql>GRANT SELECT ON mysql.columns_priv TO maxscale_route@'192.168.1.%';
mysql>GRANT SELECT ON mysql.proxies_priv TO maxscale_route@'192.168.1.%';

启动MaxScale服务

配置完成后 192.168.1.15重启MaxScale服务

[root@4e2804021a7d /]# maxscale -f /etc/maxscale.cnf.d/my.cnf -U maxscale

[root@rocky ~]# ps -ef|grep maxscale

使用 maxctrl list servers 命令查看运行状态

[root@rocky ~]# maxctrl list servers

使用 maxctrl list listeners Read-Write-Service 命令查看服务监听状态信息

[root@rocky ~]# maxctrl list listeners Read-Write-Service


http://www.ppmy.cn/news/1571457.html

相关文章

TextWebSocketHandler 和 @ServerEndpoint 各自实现 WebSocket 服务器

TextWebSocketHandler 和 ServerEndpoint 都可以用于实现 WebSocket 服务器,但它们属于不同的技术栈,使用方式和功能有一些区别。以下是它们的对比: 1. 技术栈对比 特性TextWebSocketHandler (Spring)ServerEndpoint (Java EE/JSR-356)所属框…

嵌入式知识点总结 操作系统 专题提升(五)-内存

针对于嵌入式软件杂乱的知识点总结起来,提供给读者学习复习对下述内容的强化。 目录 1.在1G内存的计算机能否malloc(1.2G)?为什么? 2.malloc能申请多大的空间? 3.内存管理有哪几种方式? 4.什…

除了Redux-Thunk,还有哪些常用的中间件?

除了 Redux-Thunk,以下是一些常用的 Redux 中间件: 1. Redux-Saga 功能:用于处理复杂的异步操作和副作用。使用生成器函数,使得异步代码更易于管理和测试。安装:npm install redux-saga2. Redux-Logger 功能:用于记录每个 dispatched action 和状态变化,便于调试。安装…

利用爬虫获取1688商品详情的实战案例指南

在电商领域,快速获取商品数据对于市场分析、竞争情报收集以及产品选品至关重要。1688作为国内领先的B2B电商平台,拥有海量的商品资源。通过爬虫技术,我们可以高效地获取这些商品的详细信息,为商业决策提供有力支持。 一、1688商品…

链式前向星_记录

链式前向星总结 测试时尽量使用静态数组 测试时尽量使用静态数组 value和next数组是可以被cnt瞬间归零的,所以只要静态给狗他俩的空间即可,使用cnt0相当于立刻清空所有内容。 head也应该设置为静态,因为无论如何head的值都要全改为-1&#x…

日志2025.2.9

日志2025.2.9 1.增加了敌人挥砍类型 2.增加了敌人的死亡状态 在敌人身上添加Ragdoll,死后激活布偶模式 public class EnemyRagdoll : MonoBehaviour { private Rigidbody[] rigidbodies; private Collider[] colliders; private void Awake() { rigidbodi…

【物联网】电子电路基础知识

文章目录 一、基本元器件1. 电阻2. 电容3. 电感4. 二极管(1)符号(2)特性(3)实例分析5. 三极管(1)符号(2)开关特性(3)实例6. MOS管(产效应管)(1)符号(2)MOS管极性判定(3)MOS管作为开关(4)MOS管vs三极管7. 门电路(1)与门(2)或门(3)非门二、常用元器件…

在服务器部署JVM后,如何评估JVM的工作能力,比如吞吐量

在服务器部署JVM后,评估其工作能力(如吞吐量)可以通过以下步骤进行: 1. 选择合适的基准测试工具 JMH (Java Microbenchmark Harness):适合微基准测试,测量特定代码片段的性能。Apache JMeter:…