千家信息网

如何使用MyCat分表分库原理分析

发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,这篇文章给大家分享的是有关如何使用MyCat分表分库原理分析的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。MyCat是一个开源的分布式数据库系统,是一个实现了MySQL协议
千家信息网最后更新 2025年02月03日如何使用MyCat分表分库原理分析

这篇文章给大家分享的是有关如何使用MyCat分表分库原理分析的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。

MyCat是一个开源的分布式数据库系统,是一个实现了MySQL协议的服务器,前端用户可以把它看作是一个数据库代理,用MySQL客户端工具和命令行访问,而其后端可以用MySQL原生协议与多个MySQL服务器通信,也可以用JDBC协议与大多数主流数据库服务器通信,其核心功能是分表分库,即将一个大表水平分割为N个小表,存储在后端MySQL服务器里或者其他数据库里。

Mycat可以实现 读写分离 分表分库

主从复制是MySQL自带的哈~

关于分片取模算法: 根据id进行取模 根据数据库集群的数量(或者说是表数量,mycat里面一个表对应一个库)

使用MyCat分表分库原理分析

Mycat中的路由结果是通过分片字段和分片方法来确定的,如果查询条件中有 id 字段的情况还好,查询将会落到某个具体的分片。如果查询没有分片的字段,会向所有的db都会查询一遍,让后封装结果级给客户端。

修改/mycat/conf/log4j2.xml日志级别为debug

比如:

在查询

select * from user_info

发送三个db请求

如果是查询素有的情况下(不带条件)

转换成为:

select * from db1.user_infoselect * from db2.user_infoselect * from db3.user_info

最后把结果集给mycat进行封装 然后返回给客户端

如果加个where id = 1 这样带条件的情况下 mycat会进行转换 1%3=1 在db2上!转换成 select * from db2.user_info where id = 1 如果查询的是分片的话,效率很高。发送一条就搞定

如果不是分片字段的话 会发送三条哦!效率很低

比如 where name = 'jack' 会发送三条 根据条件去每个数据库里面进行查询 返回结果

tailf -200f mycat.log: 进行实时的查看

然后迅速的查询 一目了然

注意分页查询:

select * from user_info limit 0,2

到底是哪个数据分片的?

往三个库里面发三个select请求 获取三对 六条结果

随机抽取一对返回给客户端

如果加了排序的条件呢?

 select * from user_info order by id  limit 0,2   (相当于取出最大的两条数据)

先发送三个select 每个都是最大的两条 然后返回给mycat 进行综合评选拿出最大的俩 返回给客户端

如果是

 select * from user_info   limit 0,3

每次请求返回的都是在改变的 是随机的!

db1 取两条 db2 和 db3随机一条

感谢各位的阅读!关于如何使用MyCat分表分库原理分析就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!

查询 数据 数据库 分库 分表 客户 客户端 条件 结果 三个 字段 服务器 服务 原理 分析 最大 情况 内容 效率 数量 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 瑶图网络技术服务中心 大手互联网科技网址 如何在服务器检查软件版本 南水北调网络安全调研提纲 浙江项目软件开发产品介绍 网络安全秘钥忘了怎么办 steam完美服务器 职业资格网络安全管理员 湖南专业软件开发五星服务 中国报纸全文数据库知识导航 ibm服务器网卡不兼容 查一个网站的数据库 手机软件开发需要多久 数据库不匹配 河北语音网络技术服务代理商 软件开发代理会计记账 数据库简单查询说课 数据库属性的闭包算法 网络安全宣传四进 数据库清空某日期字段的值 织梦更换数据库后台空白 盐城企业网络安全准入控制价格 数据库的文件名是什么文件 一年级漂亮手抄报网络安全 济南多元网络技术有限公司 为什么服务器都要虚拟化 软件开发项目目标任务单 宾夕法尼亚大学经济发展数据库 新硬盘直接插到服务器 大学生学习网络安全教育的目的
0