目录
背景:如何去实现分库分表?
当数据库进行分库分表后,数据由一个数据库分散到多个数据库中。此时系统要查询时需要切换不同的数据库进行查询,那么系统如何知道要查询的数据在哪个数据库中?当添加一条记录时要向哪个数据库中插入呢?这些问题处理起来都是非常麻烦的。
这种情况下可以使用一个数据库中间件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,这三个逻辑概念