MyCat介绍和使用

MyCAT是一个开源的数据库集群,可替代Mysql,支持SQL92标准和多种数据库集群,提供高可用性和读写分离。其关键特性包括自动故障切换、E-R分片策略等。MyCAT通过分片策略解决性能、连接过多和E-R处理等问题,支持水平和垂直分片。本文还介绍了MyCAT的下载、安装、配置以及读写分离的实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.MyCAT介绍

1.1 什么是MyCAT

简单的说,MyCAT就是:

    一个彻底开源的,面向企业应用开发的“大数据库集群”

    支持事务、ACID、可以替代Mysql的加强版数据库

    一个可以视为“Mysql”集群的企业级数据库,用来替代昂贵的Oracle集群

    一个融合内存缓存技术、Nosql技术、HDFS大数据的新型SQL Server

    结合传统数据库和新型分布式数据仓库的新一代企业级数据库产品

    一个新颖的数据库中间件产品

 

MyCAT的目标是:低成本的将现有的单机数据库和应用平滑迁移到“云”端,解决数据存储和业务规模迅速增长情况下的数据瓶颈问题。

 

1.2 MyCAT的关键特性

    支持 SQL 92标准

    支持Mysql集群,可以作为Proxy使用

    支持JDBC连接ORACLIE、DB2、SQL Server,将其模拟为MySql Server使用

    支持galera for mysql集群,percona-cluster或者mariadb cluster,提供高可用性数据分片集群

    自动故障切换,高可用性

    支持读写分离,支持Mysql双主多从,以及一主多从的模式

    支持全局表,数据自动分片到多个节点,用于高效表关联查询

    支持独有的基于E-R 关系的分片策略,实现了高效的表关联查询

    多平台支持,部署和实施简单

1.3 MyCat架构

如图所示:MyCAT使用Mysql的通讯协议模拟成了一个Mysql服务器,并建立了完整的Schema(数据库)、Table (数据表)、User(用户)的逻辑模型,并将这套逻辑模型映射到后端的存储节点DataNode(MySQL Instance)上的真实物理库中,这样一来,所有能使用Mysql的客户端以及编程语言都能将MyCAT当成是Mysql Server来使用,不必开发新的客户端协议。

 

2、MyCat解决的问题

  • 性能问题

  • 数据库连接过多

  • E-R分片难处理

  • 可用性问题

  • 成本和伸缩性问题


2.1MyCat对多数据库的支持

3、 分片策略

MyCAT支持水平分片与垂直分片:

    水平分片:一个表格的数据分割到多个节点上,按照行分隔。

    垂直分片:一个数据库中多个表格A,B,C,A存储到节点1上,B存储到节点2上,C存储到节点3上。

 

MyCAT通过定义表的分片规则来实现分片,每个表格可以捆绑一个分片规则,每个分片规则指定一个分片字段并绑定一个函数,来实现动态分片算法。

 

1、Schema:逻辑库,与MySQL中的Database(数据库)对应,一个逻辑库中定义了所包括的Table。

2、Table:表,即物理数据库中存储的某一张表,与传统数据库不同,这里的表格需要声明其所存储的逻辑数据节点DataNode。在此可以指定表的分片规则。

3、DataNode:MyCAT的逻辑数据节点,是存放table的具体物理节点,也称之为分片节点,通过DataSource来关联到后端某个具体数据库上

4、DataSource:定义某个物理库的访问地址,用于捆绑到Datanode上

 

4、MyCat的下载及安装

4.1、下载MyCat

官网地址:

http://www.mycat.org.cn/

 

GitHub地址:

https://github.com/MyCATApache

 

4.2、Mycat安装

第一步:把MyCat的压缩包上传到linux服务器

第二步:解压缩,得到mycat目录

第三步:进入mycat/bin,启动MyCat

启动命令:./mycat start

停止命令:./mycat stop

重启命令:./mycat restart

 

注意:可以使用mysql的客户端直接连接mycat服务。默认服务端口为8066

 

5、MyCat分片

5.1需求

把商品

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值