加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_泰州站长网 (http://www.0523zz.com/)- 视觉智能、AI应用、CDN、行业物联网、智能数字人!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

干货分享:MTDDL—美团点评分布式数据访问层中间件

发布时间:2019-08-12 16:48:30 所属栏目:MySql教程 来源:Wooola
导读:副标题#e# 背景 2016年Q3季度初,在美团外卖上单2.0项目上线后,商家和商品数量急速增长,预估商品库的容量和写峰值QPS会很快遇到巨大压力。随之而来也会影响线上服务的查询性能、DB(数据库,以下统一称DB)主从延迟、表变更困难等一系列问题。 要解决上面所

众所周知,分库分表首先要解决的就是分布式唯一主键的问题,业界也有很多相关方案:

干货分享:MTDDL—美团点评分布式数据访问层中间件

综上,方案3的缺点可以通过一些手段避免,但其他方案的缺点不好处理,所以选择第3种方案。目前该方案已由美团点评技术工程部实现——分布式ID生成系统Leaf,MTDDL集成了此功能。

分布式ID生成系统Leaf

美团点评分布式ID生成系统Leaf,其实是一种基于DB的Ticket服务,通过一张通用的Ticket表来实现分布式ID的持久化,执行update更新语句来获取一批Ticket,这些获取到的Ticket会在内存中进行分配,分配完之后再从DB获取下一批Ticket。整体架构图如下:

干货分享:MTDDL—美团点评分布式数据访问层中间件

每个业务tag对应一条DB记录,DB MaxID字段记录当前该Tag已分配出去的最大ID值。

IDGenerator服务启动之初向DB申请一个号段,传入号段长度如 genStep = 10000,DB事务置 MaxID = MaxID + genStep,DB设置成功代表号段分配成功。每次IDGenerator号段分配都通过原子加的方式,待分配完毕后重新申请新号段。

唯一主键生成算法扩展

MTDDL不仅集成了Leaf算法,还支持唯一主键算法的扩展,通过新增唯一主键生成策略类实现IDGenStrategy接口即可。IDGenStrategy接口包含两个方法:getIDGenType用来指定唯一主键生成策略,getId用来实现具体的唯一主键生成算法。其类图如下:

干货分享:MTDDL—美团点评分布式数据访问层中间件

分库分表

在动态数据源AOP的基础上扩展出分库分表AOP,通过分库分表ShardHandle类实现分库分表数据源路由及分表计算。ShardHandle关联了分库分表上下文ShardContext类,而ShardContext封装了所有的分库分表算法。其类图如下:

干货分享:MTDDL—美团点评分布式数据访问层中间件

分库分表流程图如下:

干货分享:MTDDL—美团点评分布式数据访问层中间件

分库分表取模算法

分库分表目前默认使用的是取模算法,分表算法为 (#shard_key % (group_shard_num * table_shard_num)),分库算法为 (#shard_key % (group_shard_num * table_shard_num)) / table_shard_num,其中group_shard_num为分库个数,table_shard_num为每个库的分表个数。

例如把一张大表分成100张小表然后散到2个库,则0-49落在第一个库、50-99落在第二个库。核心实现如下:

  1. public class ModStrategyHandle implements ShardStrategy { 
  2. @Override 
  3. public String getShardType() { 
  4. return "mod"; 
  5. @Override 
  6. public DataTableName handle(String tableName, String dataSourceKey, int tableShardNum, 
  7. int dbShardNum, Object shardValue) { 
  8. /** 计算散到表的值 */ 
  9. long shard_value = Long.valueOf(shardValue.toString()); 
  10. long tablePosition = shard_value % tableShardNum; 
  11. long dbPosition = tablePosition / (tableShardNum / dbShardNum); 
  12. String finalTableName = new StringBuilder().append(tableName).append("_").append(tablePosition).toString(); 
  13. String finalDataSourceKey = new StringBuilder().append(dataSourceKey).append(dbPosition).toString(); 
  14. return new DataTableName(finalTableName, finalDataSourceKey); 

分库分表算法扩展

MTDDL不仅支持分库分表取模算法,还支持分库分表算法的扩展,通过新增分库分表策略类实现ShardStrategy接口即可。ShardStrategy接口包含两个方法:getShardType用来指定分库分表策略,handle用来实现具体的数据源及分表计算逻辑。其类图如下:

干货分享:MTDDL—美团点评分布式数据访问层中间件

全注解方式接入

为了尽可能地方便业务方接入,MTDDL采用全注解方式使用分库分表功能,通过ShardInfo、ShardOn、IDGen三个注解实现。

ShardInfo注解用来指定具体的分库分表配置:包括分表名前缀tableName、分表数量tableShardNum、分库数量dbShardNum、分库分表策略shardType、唯一键生成策略idGenType、唯一键业务方标识idGenKey;ShardOn注解用来指定分库分表字段;IDGen注解用来指定唯一键字段。具体类图如下:

干货分享:MTDDL—美团点评分布式数据访问层中间件

(编辑:云计算网_泰州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读