Linux下使用MaxScale实现数据库读写分离

MaxScale是maridb开发的一个mysql数据中间件,其配置简单,能够实现读写分离,并且可以根据主从状态实现写库的自动切换,本篇文章重点为大家讲解一下Linux下使用MaxScale实现数据库读写分离。

操作系统:CentOS Linux release 7.3.1611 (Core)

数据库:MariaDB-10.2.6-linux-glibc_214-x86_64

MaxScale服务器:10.200.10.55

主服务器:172.16.8.56

从服务器:172.16.8.57

从服务器:172.16.8.58

1.maxscale的安装方式有很多,例如源码安装、rpm、二进制构建等,我选择二进制进行安装。

根据场景需要下载相对应的版本,下载地址;https://mariadb.com/downloads/maxscale

   [root@localhost ~]# groupadd maxscale
   [root@localhost ~]# useradd -g maxscale maxscale
   [root@localhost ~]# cd /usr/local
   [root@localhost local]# wget https://downloads.mariadb.com/MaxScale/2.1.3/centos/7server/x86_64/maxscale-2.1.3.centos.7.tar.gz
   [root@localhost local]# tar zxvf maxscale-2.1.3.centos.7.tar.gz
   [root@localhost local]# ln -s maxscale-2.1.3.centos.7 maxscale
   [root@localhost local]# cd maxscale
   [root@zhu56 maxscale]# chown -R maxscale var

建议创建软连接,这样有助于以后的版本升级及后期维护。

2.首次安装maxscale需要创建日志相关目录

   [root@localhost ~]# mkdir /var/log/maxscale
   [root@localhost ~]# mkdir /var/lib/maxscale
   [root@localhost ~]# mkdir /var/run/maxscale
   [root@localhost ~]# mkdir /var/cache/maxscale

3.以下目录必须具备maxscala用户权限

   [root@localhost ~]# chown maxscale /var/log/maxscale
   [root@localhost ~]# chown maxscale /var/lib/maxscale
   [root@localhost ~]# chown maxscale /var/run/maxscale
   [root@localhost ~]# chown maxscale /var/cache/maxscale

4.为了能让Maxscale能顺利启动,还需要创建配置文件,在Maxscale目录下有配置文件模板拷贝到etc下即可。

    [root@localhost ~]# cp /usr/local/maxscale/etc/maxscale.cnf.template /etc/maxscale.cnf

5.在修改配置文件之前,需要在主服务器上创建一个用户并给予授权,而这个用户用于MySQL监控、路由功能

   MariaDB [(none)]> create user 'jiankongdb'@'%' identified by 'jiankong123';
   MariaDB [(none)]> grant SELECT on mysql.user to 'jiankongdb'@'%';
   MariaDB [(none)]> GRANT SELECT ON mysql.db TO 'jiankongdb'@'%';
   MariaDB [(none)]> GRANT SELECT ON mysql.tables_priv TO 'jiankongdb'@'%';
   MariaDB [(none)]> GRANT SHOW DATABASES ON *.* TO 'jiankongdb'@'%';
   MariaDB [(none)]> grant REPLICATION CLIENT on *.* to 'jiankongdb'@'%';

   MariaDB [(none)]> GRANT replication slave, replication client,SELECT ON *.* TO jiankongdb@'%';

6.查看授权情况

    MariaDB [(none)]> SHOW GRANTS FOR'jiankong'@'%';

7.接下来就开始修改maxscale.cnf配置文件,否则无法启动。

   [root@localhost ~]# vim /etc/maxscale.cnf

   # MaxScale documentation on GitHub:
   # https://github.com/mariadb-corporation/MaxScale/blob/2.1/Documentation/Documentation-Contents.md

   # Global parameters
   #
   # Complete list of configuration options:
   # https://github.com/mariadb-corporation/MaxScale/blob/2.1/Documentation/Getting-Started/Configuration-Guide.md
   #全局配置
   [maxscale]
   threads=1

   # Server definitions
   #
   # Set the address of the server to the network
   # address of a MySQL server.
   #

   [server1]
   type=server
   address=172.16.8.56
   port=3306
   protocol=MySQLBackend
   serv_weight=1

   [server2]
   type=server
   address=172.16.8.57
   port=3306
   protocol=MySQLBackend
   serv_weight=3

   [server3]
   type=server
   address=172.16.8.58
   port=3306
   protocol=MySQLBackend
   serv_weight=3


   # Monitor for the servers
   #
   # This will keep MaxScale aware of the state of the servers.
   # MySQL Monitor documentation:
   # https://github.com/mariadb-corporation/MaxScale/blob/2.1/Documentation/Monitors/MySQL-Monitor.md
   #MariaDB状态监控
   [MySQL Monitor]
   type=monitor
   module=mysqlmon
   servers=server1,server2,server3
   user=jiankong
   passwd=jiankong123
   monitor_interval=10000
   detect_stale_master=true #即使从全挂掉,保证主担任读写

   # Service definitions
   #
   # Service Definition for a read-only service and
   # a read/write splitting service.
   #

   # ReadConnRoute documentation:
   # https://github.com/mariadb-corporation/MaxScale/blob/2.1/Documentation/Routers/ReadConnRoute.md
   #读
   [Read-Only Service]
   type=service
   router=readconnroute
   servers=server1,server2,server3
   user=jiankong
   passwd=jiankong123
   router_options=slave
   enable_root_user=1 #允许root用户登录执行
   weightby=serv_weight #主从权重

   # ReadWriteSplit documentation:
   # https://github.com/mariadb-corporation/MaxScale/blob/2.1/Documentation/Routers/ReadWriteSplit.md
   #写
   [Read-Write Service]
   type=service
   router=readwritesplit
   servers=server1,server2,server3
   user=jiankong
   passwd=jiankong123
   max_slave_connections=100%
   use_sql_variables_in=master #保证会话的一致性
   enable_root_user=1 #允许root登录
   max_slave_replication_lag=3600 #允许从超出主的同步时间,超出则不路由

   # This service enables the use of the MaxAdmin interface
   # MaxScale administration guide:
   # https://github.com/mariadb-corporation/MaxScale/blob/2.1/Documentation/Reference/MaxAdmin.md

   [MaxAdmin Service]
   type=service
   router=cli

   # Listener definitions for the services
   #
   # These listeners represent the ports the
   # services will listen on.
   #

   [Read-Only Listener]
   type=listener
   service=Read-Only Service
   protocol=MySQLClient
   port=4008

   [Read-Write Listener]
   type=listener
   service=Read-Write Service
   protocol=MySQLClient
   port=4006

   [MaxAdmin Listener]
   type=listener
   service=MaxAdmin Service
   protocol=maxscaled
   socket=default

保存并退出。 8.下面创建启动脚本

   [root@localhost ~]# cp /usr/local/maxscale-2.1.3.centos.7/share/maxscale.service /usr/lib/systemd/system/
   [root@localhost ~]# vim /usr/lib/systemd/system/maxscale.service

9.修改maxscale.service中的ExecStart=///bin/maxscale为ExecStart=/usr/local/maxscale/bin/maxscale

   [root@localhost ~]# chmod 755 /usr/lib/systemd/system/maxscale.service
   [root@localhost ~]# systemctl enable maxscale
   [root@localhost ~]# systemctl daemon-reload
   [root@localhost ~]# systemctl start maxscale

10.添加变量值

   [root@localhost ~]# vi /etc/profile //最后一行添加以下内容保存退出!

   PATH=$PATH:/usr/local/maxscale/bin
   export PATH

   [root@localhost ~]# source /etc/profile //使其变量立即生效

11.接下来就可以使用MaxAdmin进行管理。MaxAdmin是一个简单的客户端管理界面,可用于与MariaDB MaxScale服务器进行交互,可以显示MariaDB MaxScale内部的统计信息状态以及对MariaDB MaxScale操作的控制。详情: https://mariadb.com/kb/en/mariadb-enterprise/maxadmin-admin-interface/

   [root@localhost ~]# maxadmin //回车
   MaxScale> list servers
   Servers.
   ---------------+--------------+-------+-------------+-----------------
   Server | Address | Port | Connections | Status
   ---------------+--------------+-------+-------------+-----------------
   server1 | 172.16.8.56 | 3306 | 0 | Master, Running
   server2 | 172.16.8.57 | 3306 | 0 | Slave, Running
   server2 | 172.16.8.58 | 3306 | 0 | Slave, Running
   ---------------+--------------+-------+-------------+-----------------

12.至此MaxScale已经配置完成。现在就可以使用客户端连接Maxscale服务器端 端口为4006。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/213887.html<

(0)
运维的头像运维
上一篇2025-04-11 13:05
下一篇 2025-04-11 13:06

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注