• MariaDB MaxScale实现mysql8读写分离


    目录

    1.MaxScale 是干什么的?

    2.MaxScale 实验环境

    3.实现数据库主从复制

    4.创建用户

     1) 创建监控用户

    2) 创建路由用户

    5.docker 安装MaxScale

    6.配置maxscale

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

    查看注册服务

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


    1.MaxScale 是干什么的?

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

    2.MaxScale 实验环境

    中间件192.168.20.150MaxScale 22.08.4
    主服务器192.168.20.149mysql 8.0.30
    从服务器192.168.20.148mysql 8.0.30
    从服务器192.168.150.146mysql 8.0.30

    3.实现数据库主从复制

    分别在三台服务器的/etc/my.cnf.d/mysql-server.cnf添加:

    1. server_id=149 / 148  /146  (这个不要相同,下面两个可以相同)
    2. gtid_mode=ON
    3. enforce-gtid-consistency=ON

    两个从服务器的/etc/my.cnf.d/mysql-server.cnf添加

    read_only=1

    在主服务器添加用户

    1. create user 'rep'@'192.168.20.%' identified with mysql_native_password by '123456';
    2. --用户授权 “同步复制”、“同步复制状态”
    3. grant replication slave on *.* to 'rep'@'192.168.150.%';
    1. --配置主从同步
    2. CHANGE MASTER TO
    3. MASTER_HOST = '192.168.20.149',
    4. MASTER_USER = 'rep',
    5. MASTER_PASSWORD = '123456',
    6. MASTER_AUTO_POSITION = 1;
    7. --启动主从同步
    8. start slave

     双yes就是成功(两个从服务器都要求)

    4.创建用户

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

     1) 创建监控用户
    1. --创建用户
    2. create user 'maxscale_monitor'@'192.168.20.%' identified with mysql_native_password by 'Admin@123456';
    3. --用户授权 “同步复制”、“同步复制状态”
    4. grant replication slave, replication client on *.* to maxscale_monitor@'192.168.20.%';

    2) 创建路由用户
    1. --创建用户
    2. create user 'maxscale_route'@'192.168.20.%' identified with mysql_native_password by 'Admin@123456';
    3. --用户授权
    4. GRANT SHOW DATABASES ON *.* TO maxscale_route@'192.168.20.%';
    5. GRANT SELECT ON mysql.user TO maxscale_route@'192.168.20.%';
    6. GRANT SELECT ON mysql.db TO maxscale_route@'192.168.20.%';
    7. GRANT SELECT ON mysql.tables_priv TO maxscale_route@'192.168.20.%';
    8. GRANT SELECT ON mysql.columns_priv TO maxscale_route@'192.168.20.%';
    9. GRANT SELECT ON mysql.proxies_priv TO maxscale_route@'192.168.20.%';

    5.docker 安装MaxScale

    先安装docker,然后启动容器实例

    1. [root@openEuler-node3 ~]# yum install docker -y
    2. [root@openEuler-node3 ~]# systemctl enable --now docker
    3. [root@openEuler-node3 ~]# docker run -d --name mxs -p 8989:8989 -p 3306:3306 -v /data/maxscale/maxscale.cnf:/etc/maxscale.cnf.d mariadb/maxscale:latest
    4. Unable to find image 'mariadb/maxscale:latest' locally
    5. latest: Pulling from mariadb/maxscale
    6. 7ecefaa6bd84: Pull complete
    7. ca0e00deb174: Pull complete
    8. a477bc0ba89b: Pull complete
    9. 1197a5109a4f: Pull complete
    10. 07a9436e0cbc: Pull complete
    11. ea7a1629d291: Pull complete
    12. 22d7399fd0e3: Pull complete
    13. 9de24e307d1e: Pull complete
    14. 4b69deb551d5: Pull complete
    15. 099ea1430764: Pull complete
    16. ebc519f0dc79: Pull complete
    17. Digest: sha256:5c658141992f1b83580759137bbe1b881ebe73e07c85819e46a8a14f332ff690
    18. Status: Downloaded newer image for mariadb/maxscale:latest
    19. 832d4689e6c5f9333d089ef2fa39a6c498b10d8da7a1c414e45cb4e0db8bf9ba
    20. [root@openEuler-node3 ~]#
    21. [root@openEuler-node3 ~]# docker ps
    22. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
    23. 832d4689e6c5 mariadb/maxscale:latest "/usr/bin/tini -- do…" About a minute ago Up About a minute 0.0.0.0:3306->3306/tcp, 0.0.0.0:8989->8989/tcp mxs
    24. [root@openEuler-node3 ~]# docker exec -it mxs bash
    25. [root@832d4689e6c5 /]# maxscale -version
    26. MaxScale 23.08.4

     我们看到版本信息

    6.配置maxscale

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

    1. [root@832d4689e6c5 /]# cat /etc/maxscale.cnf.d/my.cnf
    2. [maxscale]
    3. threads=auto
    4. [dbserv1]
    5. type=server
    6. address=192.168.20.149
    7. port=3306
    8. protocol=MariaDBBackend
    9. [dbserv2]
    10. type=server
    11. address=192.168.20.148
    12. port=3306
    13. protocol=MariaDBBackend
    14. [dbserv3]
    15. type=server
    16. address=192.168.20.146
    17. port=3306
    18. protocol=MariaDBBackend
    19. [MySQL-Monitor]
    20. type=monitor
    21. module=mariadbmon
    22. servers=dbserv1, dbserv2, dbserv3
    23. user=maxscale_monitor
    24. password=Admin@123456
    25. monitor_interval=2s
    26. [Read-Write-Service]
    27. type=service
    28. router=readwritesplit
    29. servers=dbserv1,dbserv2,dbserv3
    30. user=maxscale_route
    31. password=Admin@123456
    32. enable_root_user=true
    33. [Read-Write-Listener]
    34. type=listener
    35. service=Read-Write-Service
    36. protocol=MariaDBClient
    37. address=0.0.0.0
    38. port=3306

    配置完成后重启docker、MaxScale服务:

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

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

    查看注册服务

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

     到这里服务已经完成了,测试内容我有时间分享,思路可以是:

    在master主机授权测试用户

    客户端client访问读写分离服务器

    master主机验证查看数据

    slave主机验证查看数据

    slave主机插入数据,主服务器不会同步;

    使用client客户端访问验证,能看到slave插入的数据,代表查询操作是slave主机提供服务;

  • 相关阅读:
    docker day05
    Spring Boot的运行原理
    快速入手node.js
    C# 第七章『I/O数据流』◆第5节:数据流—StreamWriter类
    Maven常见命令
    【iOS】—— 循环引用问题
    Spring Boot 常用注解大全:每个程序员必备
    API接口漏洞利用及防御
    Kafka-Connect集成clickhouse
    同花顺_代码解析_技术指标_B
  • 原文地址:https://blog.csdn.net/2201_75878485/article/details/136406327