MyCAT----读写分离

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云原生内存数据库 Tair,内存型 2GB
简介: MyCAT 是一款用 Java 开发的开源数据库中间件,需在 JDK7 以上环境运行。它位于应用与数据库间,负责数据处理与交互,支持读写分离与分库分表。部署时需先安装 JDK,再下载解压 MyCAT,并配置 `server.xml` 和 `schema.xml` 文件定义用户、逻辑库及数据节点。启动 MyCAT 后,可通过 SQL 客户端验证读写分离策略。

MyCAT读写分离

MyCAT 是一个开源的数据库系统,但是由于真正的数据库需要存储引擎,而 Mycat 并没有存 储引擎,所以并不是完全意义的数据库系统。 那么 Mycat 是什么?Mycat 是数据库中间件,就是介于数据库与应用之间,进行数据处理与交互的中间服务。

MyCAT 是使用 JAVA 语言进行编写开发,使用前需要先安装 JAVA 运行环境(JRE),由于 MyCAT 中使用了 JDK7 中的一些特性,所以要求必须在 JDK7 以上的版本上运行。

微信图片_20240831154936.png

一.部署安装JDK7以上版本;

#去官网下载JDK.tar.gz包;
#上传JDK包解压到指定目录下并重命名;
[root@mycat ~]# tar xf jdk-8u211-linux-x64.tar.gz -C /usr/local/java
#配置环境变量;
[root@mycat ~]# vim /etc/profile.d/java.sh
export JAVA_HOME=/usr/local/java
export PATH=$JAVA_HOME/bin:$PATH
#使环境变量生效
[root@mycat ~]# source /etc/profile.d/java.sh

二.安装配置MyCAT;

1.下载安装MyCAT;

#去官网下载MyCAT;
#上传MyCAT包并解压到指定目录下;
[root@mycat ~]# tar xf Mycat-server-1.6.5-DEV-20161104230656-linux.tar.gz -C /usr/local/

2.配置MyCAT;

MyCAT 目前主要通过配置文件的方式来定义逻辑库和相关配置:

/usr/local/mycat/conf/server.xml 定义用户以及系统相关变量,如端口等。其中用户信息是前端应用程序连接mycat 的用户信息。

/usr/local/mycat/conf/schema.xml 定义逻辑库,表、分片节点等内容。

1).配置server.xml

#先进入到配置文件库;
[root@mycat mycat]# cd /usr/local/mycat/conf
[root@mycat conf]# vim server.xml
<!--下面的用户和密码是应用程序连接到 MyCat 使用的.schemas 配置项所对应的值是逻辑数据库的名字,这个名字需要和后面 schema.xml 文件中配置的一致。-->

配置文件内容较多,精简到如下即可:

<?xml version="1.0" encoding="UTF-8"?>             
<!DOCTYPE mycat:server SYSTEM "server.dtd">
<mycat:server xmlns:mycat="http://io.mycat/">
        <user name="root">                                                                     <<定义登录用户名
                <property name="password">123456</property>    <<定义登录用户名密码
                <property name="schemas">company</property>
        </user>
</mycat:server>

上面的配置中,假如配置了用户访问的逻辑库,那么必须在 schema.xml 文件中也配置这个逻辑库,否则报错,启动 mycat 失败。

2).配置schema.xml

让我们看看下面几个关键定义的信息:

逻辑库和分表设置

<schema name="company"           // 逻辑库名称,与server.xml的一致
        checkSQLschema="false"    // 不检查sql
        sqlMaxLimit="100"         // 最大连接数
        dataNode="dn1">        //  数据节点名称
<!--这里定义的是分表的信息--> 

数据节点设置

<dataNode name="dn1"             // 此数据节点的名称
          dataHost="localhost1"     // 主机组
          database="student" />  // 真实的数据库名称

主机组设置

<dataHost name="localhost1"                       // 主机组
          maxCon="1000" minCon="10"               // 连接
          balance="0"                             // 负载均衡
          writeType="0"                           // 写模式配置
          dbType="mysql" dbDriver="native"        // 数据库配置
          switchType="1"  slaveThreshold="100">
<!--这里可以配置关于这个主机组的成员信息,和针对这些主机的健康检查语句-->
</dataHost>

balance 属性
负载均衡类型,目前的取值有 3 种:
1. balance="0", 不开启读写分离机制,所有读操作都发送到当前可用的 writeHost 上。
2. balance="1", 全部的 readHost 与 stand by writeHost 参与 select 语句的负载均衡,简单的说,当双主双从模式(M1->S1,M2->S2,并且 M1 与 M2 
    互为主备),正常情况下,M2,S1,S2 都参与 select 语句的负载均衡。
4. balance="2", 所有读操作都随机的在 writeHost、readhost 上分发。
5. balance="3", 所有读请求随机的分发到 writerHost 对应的 readhost 执行,writerHost 不负担读压力,注意 balance=3 只在 1.4 及其以后版本有,1.3 没有。

writeType 属性
负载均衡类型
1. writeType="0", 所有写操作发送到配置的第一个 writeHost,第一个挂了切到还生存的第二个writeHost,重新启动后已切换后的为准.
2. writeType="1",所有写操作都随机的发送到配置的 writeHost,1.5 以后废弃不推荐。

健康检查

<heartbeat>select user()</heartbeat>

读写配置,如果配置了host写解析名称即可,没有配置需要写主从ip地址,我这里也是配置了host;

<writeHost host="hostM1" url="master01:3306" user="mycat" password="Mycat@123456">
                        <!-- can have multi read hosts -->
<readHost host="hostS2" url="slave01:3306" user="mycat" password="Mycat@123456" />
</writeHost>

以下是配置了一个Mysql双主双从的MyCAT读写分离;

<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/">

        <schema name="company" checkSQLschema="false" sqlMaxLimit="100" dataNode="wh2402" >
        </schema>
        <dataNode name="wh2402" dataHost="localhost1" database="student" />
        <dataHost name="localhost1" maxCon="1000" minCon="10" balance="3"
           writeType="0" dbType="mysql" dbDriver="native" switchType="1"  slaveThreshold="100">
              <heartbeat>select user()</heartbeat>
               <writeHost host="hostM1" url="master01:3306" user="mycat" password="Mycat@123456">
               <readHost host="hostS1" url="slave01:3306" user="mycat"password="Mycat@123456">
               <writeHost host="hostM2" url="master02:3306" user="mycat" password="Mycat@123456"/>
               </writeHost>
               <writeHost host="hostM2" url="master02:3306" user="mycat" password="Mycat@123456">
               <readHost host="hostS2" url="slave02:3306" user="mycat" password="Mycat@123456">
               <writeHost host="hostM1" url="master01:3306" user="mycat" password="Mycat@123456"/>
               </writeHost>
</mycat:schema>

3).启动MyCAT;

[root@mycat ~]# /usr/local/mycat/bin/mycat  start
#MyCAT支持的参数
start | restart |stop | status

4).创建schema.xml里配置的对应权限用户;

#在真实的master上创建用户;
mysql> grant all on testdb.* to mycat@'%' identified by 'Mycat@123';
mysql> flush privileges;

#登录MyCAT看看逻辑库company对应真实的数据库student内容是否一致;
[root@mycat~]# mysql -uroot -p123456 -h192.168.73.133 -P 8066   <<这里的IP为你的mycatip
#查询逻辑库是否存在;
MySQL [(none)]> show databases;
+----------+
| DATABASE |
+----------+
|  company |
+-----------
1 row in set (0.00 sec)

继续测试读写分离策略

使用 mysql 客户端工具使用 mycat 的账户和密码登录 mycat ,

之后执行 select 语句。

之后查询 mycat 主机上 mycat 安装目录下的 logs/mycat.log 日志。

在日志重搜索查询的语句或者查询 从库的 ip 地址,应该能搜索到

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
11月前
|
SQL 关系型数据库 MySQL
MyCat2介绍以及部署和读写分离/分库分表(MyCat2.0)
MyCat2介绍以及部署和读写分离/分库分表(MyCat2.0)
709 0
|
14天前
|
SQL 关系型数据库 MySQL
MySQL----配置双主双从
本文档详细介绍了如何在四台服务器上配置MySQL的双主双从架构。首先,通过关闭防火墙和SELinux确保网络通信畅通无阻。接着,设置各服务器的主机名和本地Host,确保名称解析正确。然后,通过YUM安装MySQL并修改初始密码。接下来,逐步配置四个节点(master01、master02、slave01、slave02),包括修改配置文件、创建用户和授权等步骤,实现主从复制。最后,通过SQL命令验证主从同步是否成功。
|
1月前
|
cobar 关系型数据库 MySQL
使用MyCat实现MySQL主从读写分离(一)概述
【8月更文挑战第11天】MySQL读写分离通过主从复制分散负载,主库负责写操作,从库承担读查询,以复制技术确保数据一致性。此策略有效缓解锁竞争,提升查询效能并增强系统可用性。实现方式包括应用层处理,简便快捷但灵活性受限;或采用中间件如MyCAT、Vitess等,支持复杂场景但需专业团队维护。
42 0
|
4月前
|
中间件 数据库
mycat2.X读写分离
mycat2.X读写分离
129 9
|
11月前
|
SQL cobar 应用服务中间件
03MyCat - MyCat的前世今生
03MyCat - MyCat的前世今生
81 1
|
运维 关系型数据库 MySQL
MyCat-架构剖析-MyCat 主从切换实现 | 学习笔记
快速学习 MyCat-架构剖析-MyCat 主从切换实现
668 0
MyCat-架构剖析-MyCat 主从切换实现 | 学习笔记
|
SQL 关系型数据库 MySQL
Mycat的读写分离
MySQL主从复制原理
78 1
|
负载均衡 关系型数据库 MySQL
MyCat - 高级 - 读写分离 - MyCat 实现 MySQL 双主双从读写分离 | 学习笔记
快速学习 MyCat - 高级 - 读写分离 - MyCat 实现 MySQL 双主双从读写分离
118 0
MyCat - 高级 - 读写分离 - MyCat 实现 MySQL 双主双从读写分离 | 学习笔记
|
存储 SQL 关系型数据库
MyCat-集群-MySQL 主从复制配置 | 学习笔记
快速学习 MyCat-集群-MySQL 主从复制配置
146 0
MyCat-集群-MySQL 主从复制配置 | 学习笔记
|
SQL 缓存 监控
MyCat - 分片 - MyCat 监控 | 学习笔记
快速学习 MyCat - 分片 - MyCat 监控
100 0
MyCat - 分片 - MyCat 监控 | 学习笔记