MariaDB MaxScale实现mysql8读写分离

MariaDB MaxScale实现mysql8读写分离

1.MaxScale 是干什么的?

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

2.MaxScale 实验环境

中间件

192.168.0.160

MaxScale 22.08.4

主服务器

192.168.0.161

mysql 8.0.32

从服务器

192.168.0.162

mysql 8.0.32

3.实现数据库主从复制

4.创建用户

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

1) 创建监控用户

--创建用户

create user 'maxscale_monitor'@'%' identified with mysql_native_password by 'Admin@123456';

--用户授权 “同步复制”、“同步复制状态”

grant replication slave, replication client on *.* to maxscale_monitor@'%';

2) 创建路由用户

--创建用户

create user 'maxscale_route'@'%' identified with mysql_native_password by 'Admin@123456';

--用户授权

GRANT SHOW DATABASES ON *.* TO maxscale_route@'%';

GRANT SELECT ON mysql.user TO maxscale_route@'%';

GRANT SELECT ON mysql.db TO maxscale_route@'%';

GRANT SELECT ON mysql.tables_priv TO maxscale_route@'%';

GRANT SELECT ON mysql.columns_priv TO maxscale_route@'%';

GRANT SELECT ON mysql.proxies_priv TO maxscale_route@'%';

5.安装MaxScale

在 https://mariadb.com/downloads/ 选择对应系统合适的版本下载安装,我这里使用docker 安装

# 管理后台端口8989,3306中间件连接端口

docker run -d --name mxs -p 8989:8989 -p 3306:3306 -v /data/maxscale/maxscale.cnf:/etc/maxscale.cnf.d mariadb/maxscale:latest

启动后 可登录到docker容器,查看MaxScale版本与日志信息

# 登录容器

docker exec -it b19aa816ca93 bassh

# 查看版本信息

maxscale -version

# 查看版本日志

cat /var/log/maxscale/maxscale.log

6.配置maxscale

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

[maxscale]

# 开启线程个数,默认为1.设置为auto会同cpu核数相同

threads=auto

# 定义服务器主机1

[dbserv1]

type=server

address=192.168.0.161

port=3306

protocol=MariaDBBackend

# 定义服务器主机2

[dbserv2]

type=server

address=192.168.0.162

port=3306

protocol=MariaDBBackend

#监视进程

[MySQL-Monitor]

type=monitor

module=mariadbmon

servers=dbserv1, dbserv2

user=maxscale_monitor # 之前在master上创建的监视用户,监视服务器dbserv1, dbserv2运行状态

password=Admin@123456

monitor_interval=2s

# 读写分离,

[Read-Write-Service]

type=service

router=readwritesplit

servers=dbserv1,dbserv2

user=maxscale_route # 之前在master上创建的路由用户,请求转发到 数据库服务器

password=Admin@123456

enable_root_user=true # 默认禁止root用户访问,设置为1开启

# 监听读写服务端口

[Read-Write-Listener]

type=listener

service=Read-Write-Service

protocol=MariaDBClient

address=0.0.0.0

port=3306

配置完成后 重启MaxScale服务,进入容器中 可:

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

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

可通过GUI WEB图形页面访问http://172.16.1.51:8989查看,登录名admin,密码mariadb:

7.客户端连接测试

1)在 master中创建一个访问用,已经实现主从复制的前提下,主库创建的用户,能同步到从库上

-- 创建用户

create user 'admin_user'@'%' identified with mysql_native_password by 'Admin@123456'; --msql 8.0.x 用户认证的方式需要修改为 mysql_native_password

--用户授权

grant all privileges on *.* to 'admin_user'@'%' with grant option;

2) 可以在从库中 slave(192.168.0.161) 新增一条数据,登录主库 master(192.168.0.161) 进行查询如果查询不到,在中间件连接库中 maxscale(192.168.0.160) 可以查询到则成功

相关推荐

电脑自带ppt在哪(powerpoint在电脑上怎么找)
英国365老板

电脑自带ppt在哪(powerpoint在电脑上怎么找)

📅 07-31 👁️ 4510
ISO感光度
英国365老板

ISO感光度

📅 09-03 👁️ 3297
中国男明星有哪些? 中国有家暴的男明星有哪些?
365网站是正规平台吗

中国男明星有哪些? 中国有家暴的男明星有哪些?

📅 08-25 👁️ 6860