ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Mycat的分库功能的路由查找(计算)的实现

2021-03-05 21:54:16  阅读:192  来源: 互联网

标签:分库 函数 algorithm Mycat 计算 规则 路由


在开源的mysql中间件中,MyCat貌似比较火,实际使用,可能依然存在不少的缺陷(Mycat官方网站上也有注明,可能需要买支持),要想真正用于生产,还必须得把它全部吃透,并结合应用,规避(强悍者可以修正)其缺陷,做好充分的测试。

前段时间稍微研究了一下它的路由计算的实现,因为忙其他的事情,一转眼,很长一段时间已经过去了,自己都差不多忘了当初跟踪到的路由计算的核心代码。 今天再翻出来梳理一下,记点小笔记,以免过段时间又忘了。

Mycat 中的路由计算是通过函数ruleCalculate来实现的。函数代码如下:


图片
  该函数有两个入参:

1。 一个是表的配置信息,其中包含了表的路由规则。

2。另外一个就是where条件里面抽取的信息,用来计算路由规则。

进入函数体之后,

第一步:创建一个空的hash 集合,用于存放路由。

第二步:通过表的配置信息,找到用于分区的列。

第三步:获取路由规则。

第四步:通过路由规则获取具体的路由算法类。

第五步:正式计算路由。 分两种情况,一个是等值计算, 调用algorithm.calculate()函数进行计算路由。

还有一个是范围计算。则调用algorithm.calculateRange()函数进行计算路由。


algorithm 是一个抽象类,具体调用的计算方法由其具体化的类决定。 如果表的路由规则是partitionbylong, 则会调用下面的函数。



最后真正返回路由结果的,是由PartionUtil.partition(key) 函数来返回的,返回的node的编号,通过编号,我们可以知道node的物理位置,然后成功路由。


所有的路由算法的实现都是具体化这个抽象类algorithm来实现的,因此,可以随意添加自己实现的类,来实现自己的新的路由规则。


在Mycat 中,计算路由是第一个步,如果涉及到join的,涉及到两个表的路由, 两个表之间如何关联,结果如何合并? 合并的结果是否是一个正常的结果? 这些,在实际测试过程中,发现两个表的join的功能还有待完善。


标签:分库,函数,algorithm,Mycat,计算,规则,路由
来源: https://blog.51cto.com/15057824/2648687

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有