操作系统:CentOS7 (Core)

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

MaxScale服务器:192.168.40.134

主服务器:192.168.40.132

从服务器:192.168.40.133

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'jiankongdb'@'%';

注意:

在/var/lib/maxscale文件夹上面建立文件夹.secrets,然后使用命令:maxkeys .secrets/生成加密文件.secrets。再把这个.secrets文件拷贝到/var/lib/maxscale下面,而且这个.secrets文件的格式为:

-r--------   1 maxscale maxscale   48 5月  29 15:54 .secrets

再使用这个文件生成密码:

在当前目录使用指令:maxpasswd  jiankong123生成密码C5828F2BBE20D9758BDECF33173C0317,到时候需要用到。

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=192.168.40.132

port=3306

protocol=MySQLBackend

serv_weight=1

[server2]

type=server

address=192.168.40.133

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

user=jiankongdb

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

user=jiankongdb

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 假如该指令运行失败,可以尝试以下指令:maxscale --config=/etc/maxscale.cnf

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。

在MaxAdmin客户端管理界面进行操作:

停止MaxScale:shutdown maxscale

停止monitor:shutdown monitor

shutdown service

shutdown listener

转载于:https://www.cnblogs.com/kinwing/p/11132030.html

MaxScale中间件部署数据库读写分离相关推荐

  1. 基于MaxScale中间件的MySQL读写分离

    基于MaxScale中间件的MySQL读写分离 概述 maxscale 基于keepalived的高可用,通过VIP提供服务 maxscale官网:https://mariadb.com/downlo ...

  2. 018:Django商城部署和数据库读写分离

    本章知识点 1.Centos下python3环境的部署 2.Python uwsgi 3.Python uwsgi+nginx部署 4.mysql主从备份介绍 5.Linux下的mysql安装 6.基 ...

  3. MySQL 基于maxscale服务构建数据读写分离

    目录 MySQL 基于maxscale服务构建数据读写分离 读写分离概述 读写分离原理 MySQL读写分离 案例拓扑 构建读写分离 构建思路 基于maxscale服务配置数据读写分离 配置mysql一 ...

  4. Centos7+LAMP+owncloud+数据库读写分离

    1. Mysql-5.6.40 软件包存放目录:/usr/local/src/ 1.1 安装mysql cd /usr/local/src/ # 1.切换到软件包目录wget http://...my ...

  5. 数据库读写分离数据延迟解决方案

    一.数据库系统架构发展 1.主备架构 业务发展的前期,数据访问量小,这时我们可以直接采用单库的架构. 不过我们一般不使用的上面的架构,因为存在单点的问题.若数据库出现故障,这段期间业务将会不可用.我们 ...

  6. 数据库读写分离,主从同步实现方法

    前言 众所周知,随着用户量的增多,数据库操作往往会成为一个系统的瓶颈所在,而且一般的系统"读"的压力远远大于"写",因此我们可以通过实现数据库的读写分离来提高系 ...

  7. 跟我学Springboot开发后端管理系统5:数据库读写分离

    在Matrix-web后台管理系统中,使用到了数据库的读写分离技术.采用的开源的Sharding-JDBC作为数据库读写分离的框架.Matrix-Web后台数据库这一块采用的技术栈如下: 使用Myba ...

  8. 解决数据库读写分离(转)

    如何配置mysql数据库的主从? 单机配置mysql主从:http://my.oschina.net/god/blog/496 常见的解决数据库读写分离有两种方案 1.应用层 http://neore ...

  9. 学会数据库读写分离、分表分库

    https://www.cnblogs.com/joylee/p/7513038.html 系统开发中,数据库是非常重要的一个点.除了程序的本身的优化,如:SQL语句优化.代码优化,数据库的处理本身优 ...

最新文章

  1. DSP学习-- UTC转UNIX时间戳
  2. java笔记之线程方式1启动线程
  3. 【nginx】nginx 反向代理 指令说明
  4. line划线计算机图像学,【计算机图形学】根本图形元素:直线的生成算法
  5. 【“零起点”--百度地图手机SDK】如何创建一张地图
  6. UVA10284 POJ2512 Chessboard in FEN【国际象棋】
  7. 如何建立自己的轻量级 UI 测试工具
  8. Java面向对象总复习-QuickHit
  9. Linux下压缩mp3文件
  10. HDFS优缺点及解决方案
  11. 取模运算和求余运算的区别
  12. 网页超链接无法访问本地文件
  13. C# 设置文件默认打开程序
  14. python实现qq登录界面_Python实现QQ界面
  15. 2019年5月25更新——“运动世界校园”软件破解
  16. 基于android的门禁系统代码,基于ESP8266 base on esp8266门禁系统 安卓源码
  17. 华为电脑如何投屏到电视linux,华为mate10/mate10pro怎么投屏至电视或电脑上面?
  18. laravel表单提交419解决办法
  19. 离散数学 第十六章 环和域
  20. font-awesome图标显示问题解决方案

热门文章

  1. 一些C#实用的方法汇总
  2. 【Java从0到架构师】SpringBoot - 入门_配置文件_YAML
  3. 【并查集】Union Find
  4. 小程序入门学习05--幻灯片、页面生命周期
  5. Windows没有关机按钮 如何使用命令行关机 重启
  6. 在Tomcat上部署WebService服务
  7. 月薪2w的00后女财务,靠这套报表模板征服了老板
  8. 自带python库的环境软件_pyenv虚拟环境管理python多版本和软件库
  9. App.vue文件本质上也是js文件(javascript文件)
  10. python selenium环境安装及配置_selenium环境配置