Mycat读写分离配置实践

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
简介:    工作这些年来,也去了一些地方,有了一些见闻,隐隐感觉很多文化和猫有着千丝万缕的联系。就拿IT行业来说吧,猫有着很高的曝光率,比如大名鼎鼎的 tomcat,是由SUN的软件构架师詹姆斯·邓肯·戴维森开发,并由Sun贡献给Apache软件基金会,他希望这种动物能够自己照顾自己,将其命名为 Tomcat,于是乎这个名字就留下来了。

   工作这些年来,也去了一些地方,有了一些见闻,隐隐感觉很多文化和猫有着千丝万缕的联系。就拿IT行业来说吧,猫有着很高的曝光率,比如大名鼎鼎的 tomcat,是由SUN的软件构架师詹姆斯·邓肯·戴维森开发,并由Sun贡献给Apache软件基金会,他希望这种动物能够自己照顾自己,将其命名为 Tomcat,于是乎这个名字就留下来了。

  在Oracle中我最喜欢查看的一个数据字典试图就是cat,这是典型的猫文化,没有其他的技术意味。

  最早听到mycat的时候,我意味是一个国外的开源项目,但是紧接着发现这竟然是一个国产项目,让我有些激动,而且源代码是基于Java的,我觉得太对我的胃口了。

  下面的猫儿是在泰国皮皮岛的一个早晨碰见的,它睡在门口,眼皮都懒得抬一下。

  mycat这么一个项目,在国内确实很火,在github上也有链接,星标有2000多个。是基于阿里开源的Cobar产品而研发。

  github链接如下:

https://github.com/MyCATApache/Mycat-Server/wiki

  官方的链接如下:

http://dl.mycat.io/目前的版本比较新的是1.6,摸爬滚打这么多年,也算是见证了国内数据库的一个发展,它本身不仅仅支持MySQL,还支持Oracle,PG等,目前MySQL方向用的最为流行。

安装部署

Mycat的安装部署其实很简单,从官方下载对应的安装包即可,大概是15M左右。

下载最新的安装包:

wget http://dl.mycat.io/1.6-RELEASE/Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz

 解压后的安装包内容有60M左右。

安装Mycat很简单,只需要保证Java已经正确安装,如果系统自带,版本不低也可以。

# java -version
java version "1.7.0_45"
OpenJDK Runtime Environment (rhel-2.4.3.3.0.1.el6-x86_64 u45-b15)
OpenJDK 64-Bit Server VM (build 24.45-b08, mixed mode)相应的Java的基础配置也需要在profile文件里对应调整一下。

比如修改.bash_profile文件。

export JAVA_HOME=/usr/lib/jvm/jre-1.7.0-openjdk.x86_64
export PATH=$PATH:$JAVA_HOME/bin
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar

创建系统级的组和用户

useradd mycat对于安装来说,几乎不需要可以调整,直接把解压后的mycat目录拷贝到/usr/local下即可,然后修改权限。

mv mycat/ /usr/local/
chown mycat:mycat /usr/local/mycat


配置数据库环境

我们需要配置的数据库环境假设是一主三从,可以在一台服务器上搭建模拟,一主三从如果快速搭建部署,可以参考github上我写的一个小脚本,https://github.com/jeanron100/mysql_slaves,分分钟搞定。

假设环境的情况如下:

master:   端口33091
slave1:   端口33092
slave2:   端口33093
slave3:   端口33093

mycat可以实现很多功能,在此先实现一个需求,比如现在有一套环境读多写少,需要提供大量的数据量连接访问。我们就可以创建两个用户mycat_user,负责DML,mycat_read负责查询。create user mycat_user identified by 'mycat';
create user mycat_read identified by 'mycat';

比如有多个数据库,我们就模拟创建3个数据库来。

create database db1;
create database db2;
create database db3;

分配权限的部分如下:

grant select on db1.* to mycat_read;
grant select,insert,delete,update on db1.* to mycat_user;

grant select on db2.* to mycat_read;
grant select,insert,delete,update on db2.* to mycat_user;

grant select on db3.* to mycat_read;
grant select,insert,delete,update on db3.* to mycat_user;赋予从库状态查询的权限,在后面需要用。

mysql> grant replication client on *.* to 'mycat_read'@'%' ;
mysql> grant replication client on *.* to 'mycat_user'@'%' ;

初始化数据

初始化数据库,我还是选用一个经典的标travelrecord,然后插入两行记录。在3个数据库db1,db2,db3中创建。

mysql> create table travelrecord
(id bigint not null primary key,user_id varchar(100),traveldate DATE, fee decimal,days int);

mysql>  insert into travelrecord(id,user_id,traveldate,fee,days)  values(1,@@hostname,20160101,100,10);

mysql> insert into travelrecord(id,user_id,traveldate,fee,days)  values(5000001,@@hostname,20160102,100,10);


mycat配置

 上面的工作做好之后,系统层面,数据库层面的工作就做好了。启动Mycat的命令很简单,比如mycat start,停止Mycat的命 令 mycat stop等等。

  命令很简单,关键在于Mycat的配置,这个才是重点。在mycat/conf目录下有两个文件需要重点关注,一个是server.xml,一个是schema.xml

  server.xml的配置关键内容如下,我们配置了两个用户,所以在这个配置文件里就先按照如下的配置,这里我们配置schema是pxc_schema,先卖个关子。

        <user name="mycat_user">
                <property name="password">mycat</property>
                <property name="schemas">pxc_schema</property>
        </user>
        <user name="mycat_read">
                <property name="password">mycat</property>
                <property name="schemas">pxc_schema</property>
                <property name="readOnly">true</property>
        </user>
</mycat:server>

  schema.xml的内容如下,也做了相应的标注。

<?xml version="1.0"?> 
    <!DOCTYPE mycat:schema SYSTEM "schema.dtd"> 
    <mycat:schema xmlns:mycat="http://io.mycat/">          
        <!-- 定义MyCat的逻辑库 --> 
        <schema name="pxc_schema" checkSQLschema="false" sqlMaxLimit="100" dataNode="pcxNode"></schema>       
        <!-- 定义MyCat的数据节点 --> 
        <dataNode name="pcxNode" dataHost="dtHost" database="db1" />                 
        <!-- 定义数据主机dtHost,连接到MySQL读写分离集群 ,schema中的每一个dataHost中的host属性值必须唯一--> 
        <!-- dataHost实际上配置就是后台的数据库集群,一个datahost代表一个数据库集群 --> 
        <!-- balance="1",全部的readHost与stand by writeHost参与select语句的负载均衡--> 
        <!-- writeType="0",所有写操作发送到配置的第一个writeHost,这里就是我们的hostmaster,第一个挂了切到还生存的第二个writeHost--> 
        <dataHost name="dtHost" maxCon="500" minCon="20" balance="1" 
            writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100"> 
            <!--心跳检测 --> 
            <heartbeat>show slave status</heartbeat>            
            <!--配置后台数据库的IP地址和端口号,还有账号密码,这里我们可以根据需要来配置,比如一主三从的环境 --> 
            <writeHost host="hostMaster" url="192.168.163.128:33091" user="mycat_user" password="mycat" /> 
            <writeHost host="hostSlave1" url="192.168.163.128:33092" user="mycat_read" password="mycat" /> 
            <writeHost host="hostSlave2" url="192.168.163.128:33093" user="mycat_read" password="mycat" /> 
            <writeHost host="hostSlave3" url="192.168.163.128:33094" user="mycat_read" password="mycat" /> 
        </dataHost> 
</mycat:schema>

检测Mycat的连接情况

Mycat的配置做好了以后,整个工作的80%的任务就完成了,其实关键还是在于Mycat文件的配置,配置不当还是需要反复调试的。

如果验证Mycat的生效呢,我们可以使用8066这个默认端口来连接,如果里面出现mycat的字样,就证明是Mycat设置生效了。

[root@oel64 logs]# mysql -umycat_read -pmycat -P8066  -h192.168.163.128
。。。
Server version: 5.6.29-mycat-1.6-RELEASE-20161028204710 MyCat Server (OpenCloundDB)
。。。
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

我们看看这个用户mycat_read能够访问的数据库,在数据库里应该就是db1,db2,db3,为什么这里出现了pxc_shema呢,其实也可以理解是Mycat在中间过滤的效果,其实这是db1,而db2,db3还没有在Mycat配置文件中体现,所以还没有生效。

mysql> show databases;
+------------+
| DATABASE   |
+------------+
| pxc_schema |
+------------+
1 row in set (0.00 sec)我们就连接到这个pxc_schema数据库。

mysql> use pxc_schema
Database changed

可以看到这个数据库下的表。

mysql> show tables;
+---------------+
| Tables_in_db1 |
+---------------+
| travelrecord  |
+---------------+
1 row in set (0.01 sec)

如果验证我们连接到的数据库是启用了Mycat的读写分离呢。我们可以看端口。

mysql> select @@port;
+--------+
| @@port |
+--------+
|  33092 |
+--------+
1 row in set (0.05 sec)

由此我们可以看到,连接到的是33092的端口,即是slave1
可以反复切换,看看这个load balance的方式是否满意。


继续扩展Mycat读写分离的配置

上面的步骤只是简单实现了读写分离的配置,比如我要访问多个数据库,而不仅仅是pxc_schema,该如何配置呢。

我们在server.xml中就需要对schema扩展一下,schema的值是以逗号分隔,配置的细节是在schema.xml里面映射的。

<user name="mycat_user">
                <property name="password">mycat</property>
                <property name="schemas">pxc_schema,db2,db3</property>
        </user>

        如果在schema.xml里面配置多个 逻辑库,就可以配置多个schema键值即可。        

  <schema name="pxc_schema" checkSQLschema="false" sqlMaxLimit="100" dataNode="pcxNode"></schema> 
  <schema name="db2" checkSQLschema="false" sqlMaxLimit="100" dataNode="pcxNode2"></schema> 
  <schema name="db3" checkSQLschema="false" sqlMaxLimit="100" dataNode="pcxNode3"></schema>       相应的dataNode也需要扩展映射。  

<dataNode name="pcxNode" dataHost="dtHost" database="db1" /> 
<dataNode name="pcxNode2" dataHost="dtHost" database="db2" /> 
<dataNode name="pcxNode3" dataHost="dtHost" database="db3" />        整个过程完成后,重启一下Mycat即可。



   

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
8天前
|
人工智能 JSON 供应链
畅用7个月无影 JVS Claw |手把手教你把JVS改造成「科研与产业地理情报可视化大师」
LucianaiB分享零成本畅用JVS Claw教程(学生认证享7个月使用权),并开源GeoMind项目——将JVS改造为科研与产业地理情报可视化AI助手,支持飞书文档解析、地理编码与腾讯地图可视化,助力产业关系图谱构建。
23428 9
畅用7个月无影 JVS Claw |手把手教你把JVS改造成「科研与产业地理情报可视化大师」
|
17天前
|
缓存 人工智能 自然语言处理
我对比了8个Claude API中转站,踩了不少坑,总结给你
本文是个人开发者耗时1周实测的8大Claude中转平台横向评测,聚焦Claude Code真实体验:以加权均价(¥/M token)、内部汇率、缓存支持、模型真实性及稳定性为核心指标。
6459 25
|
12天前
|
人工智能 缓存 BI
Claude Code + DeepSeek V4-Pro 真实评测:除了贵,没别的毛病
JeecgBoot AI专题研究 把 Claude Code 接入 DeepSeek V4Pro,跑完 Skills —— OA 审批、大屏、报表、部署 5 大实战场景后的真实体验 ![](https://oscimg.oschina.net/oscnet/up608d34aeb6bafc47f
4168 13
Claude Code + DeepSeek V4-Pro 真实评测:除了贵,没别的毛病
|
13天前
|
人工智能 JSON BI
DeepSeek V4 来了!超越 Claude Sonnet 4.5,赶紧对接 Claude Code 体验一把
JeecgBoot AI专题研究 把 Claude Code 接入 DeepSeek V4Pro 的真实体验与避坑记录 本文记录我将 Claude Code 对接 DeepSeek 最新模型(V4Pro)后的真实体验,测试了 Skills 自动化查询和积木报表 AI 建表两个场景——有惊喜,也踩
5015 13
|
29天前
|
人工智能 自然语言处理 安全
Claude Code 全攻略:命令大全 + 实战工作流(建议收藏)
本文介绍了Claude Code终端AI助手的使用指南,主要内容包括:1)常用命令如版本查看、项目启动和更新;2)三种工作模式切换及界面说明;3)核心功能指令速查表,包含初始化、压缩对话、清除历史等操作;4)详细解析了/init、/help、/clear、/compact、/memory等关键命令的使用场景和语法。文章通过丰富的界面截图和场景示例,帮助开发者快速掌握如何通过命令行和交互界面高效使用Claude Code进行项目开发,特别强调了CLAUDE.md文件作为项目知识库的核心作用。
23248 65
Claude Code 全攻略:命令大全 + 实战工作流(建议收藏)