MyCat

目录

背景:如何去实现分库分表?

1.什么是MyCat

2.MyCat的分片策略

 执行原理


背景:如何去实现分库分表?

当数据库进行分库分表后,数据由一个数据库分散到多个数据库中。此时系统要查询时需要切换不同的数据库进行查询,那么系统如何知道要查询的数据在哪个数据库中?当添加一条记录时要向哪个数据库中插入呢?这些问题处理起来都是非常麻烦的。

这种情况下可以使用一个数据库中间件mycat来解决相关的问题。接下来了解一下什么是mycat

1.什么是MyCat

MyCat是目前最流行的基于java编写的数据库中间件,是一个实现了Mysql协议的服务器,前端用户可以把它看作是一个数据库代理,用Mysql客户端工具和命令行访问,而其后端可以用MySQL原生协议与多个MySQL服务器通信,也可以用JDBC协议与大多数主流数据库服务器通信,其核心功能是分库分表和读写分离,即将一个大表水平分割为N个小表,存储在后端MySql服务器里面或者其他数据库里面。

mycat对于我们程序员来说,就是一个近似等于MySQL的数据库服务器,你可以用连接Mysql的方式去连接mycat(除了端口不同,默认的mycat端口是8066而非3306,因此需要在连接字符串上加上端口信息)

2.MyCat的分片策略

  • 什么是分片?
    • 通过某种特定的条件,将我们存放在同一个数据库中的数据分散存放到多个数据库上面,以达到分散单台设备负载的效果
  • MyCat支持两种切分模式
    • 一种是按照不同的表来切分到不同得到数据库之上,这种切分可以称为垂直切分
    • 另外一种是根据表中的数据逻辑关系,将同一个表中的数据按照某种条件拆分到多台数据库中,这种称为水平切分

 绿色部分全是MyCat中间件里面的逻辑库和逻辑表以及逻辑分片节点,下面蓝色的才是实际上的存储位置

 

 执行原理

应用程序首先会发送sql到mycat,mycat解析sql去确定在哪个分片节点上去执行,通过datanode节点去找到对应的实体数据库信息。安装mycat需要自己手动配置scheam、Table、datanode,这三个逻辑概念

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值