[发明专利]生成分布式ID的系统和方法在审
申请号: | 202110566730.8 | 申请日: | 2021-05-24 |
公开(公告)号: | CN113297327A | 公开(公告)日: | 2021-08-24 |
发明(设计)人: | 贾宁 | 申请(专利权)人: | 建信金融科技有限责任公司 |
主分类号: | G06F16/27 | 分类号: | G06F16/27;G06F9/50;G06F16/22 |
代理公司: | 中原信达知识产权代理有限责任公司 11219 | 代理人: | 李阳;宗磊 |
地址: | 200120 上海市自由*** | 国省代码: | 上海;31 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 生成 分布式 id 系统 方法 | ||
1.一种生成分布式ID的系统,其特征在于,包括分布式数据库集群、第一服务器集群和第二服务器集群;
其中,所述分布式数据库集群,用于生成并存储ID可用号段,所述ID可用号段中包括多个依次增大的可用序列值;
所述第一服务器集群,用于确定所述第二服务器集群中每个第二服务器的ID;其中,所述每个第二服务器的ID依次增大;
所述第二服务器集群,用于获取所述ID可用号段和各第二服务器的ID,根据所述ID可用号段和各第二服务器的ID,生成多个可用业务ID;以及根据ID申请请求,从所述多个可用业务ID中确定与所述ID申请请求对应的目标业务ID。
2.根据权利要求1所述的系统,其特征在于,所述分布式数据库集群还用于设置所述ID可用号段的位数;所述第一服务器集群还用于设置所述第二服务器的ID的位数;所述第二服务器集群还用于设置所述可用业务ID的位数。
3.根据权利要求2所述的系统,其特征在于,每个所述第二服务器还用于:将所述ID可用号段中的每个所述可用序列值与所述第二服务器的ID进行拼接,若拼接后得到的可用序列值的位数小于所述可用业务ID的位数,则对拼接后得到的可用序列值进行补齐,将补齐后的可用序列值作为可用业务ID。
4.根据权利要求3所述的系统,其特征在于,所述第二服务器还用于:将所述多个可用业务ID写入预设的环形数组,以及从所述环形数组中获取与所述ID申请请求对应的目标业务ID。
5.根据权利要求4所述的系统,其特征在于,所述第二服务器还用于:
创建多个环形数组,所述多个环形数组对应不同的业务类型;确定所述多个可用业务ID对应的业务类型,将所述多个可用业务ID写入与其业务类型对应的环形数组中;以及根据所述ID申请请求对应的业务类型,从所述多个环形数组中确定目标环形数组,从所述目标环形数组中获取与所述ID申请请求对应的目标业务ID。
6.根据权利要求5所述的系统,其特征在于,所述第二服务器还用于:将所述环形数组存储在中央处理器缓存中,使所述环形数组中的每个可用业务ID占用一个中央处理器缓存线。
7.根据权利要求1-6任一项所述的系统,其特征在于,所述分布式数据库集群包括多个分布式数据库,所述多个分布式数据库分布在多个城市的多个机房中;
所述第一服务器集群包括多个第一服务器,所述多个第一服务器分布在所述多个城市的多个机房中;
所述第二服务器集群包括多个第二服务器,所述多个第二服务器分布在所述多个城市的多个机房中。
8.根据权利要求7所述的系统,其特征在于,当所述第二服务器在获取所述ID可用号段时,从与所述第二服务器安装在同一机房的分布式数据库中获取。
9.根据权利要求8所述的系统,其特征在于,所述系统还包括负载均衡装置,用于接收所述ID申请请求,并确定与所述ID申请请求对应的目标机房以及所述目标机房中的目标第二服务器,以使所述目标第二服务器确定与所述ID申请请求对应的目标业务ID。
10.根据权利要求9所述的系统,其特征在于,所述负载均衡装置还用于:确定所述ID申请请求对应的权重;基于所述权重,确定与所述ID申请请求对应的目标机房以及所述目标机房中的目标第二服务器。
11.根据权利要求10所述的系统,其特征在于,所述权重包括第一权重和第二权重;
所述负载均衡装置还用于:根据所述第一权重,确定与所述ID申请请求对应的目标机房;根据所述第二权重,确定与所述ID申请请求对应的目标机房中的目标第二服务器。
12.根据权利要求9所述的系统,其特征在于,所述负载均衡装置还用于定时检测所述多个第二服务器的工作状态。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于建信金融科技有限责任公司,未经建信金融科技有限责任公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202110566730.8/1.html,转载请声明来源钻瓜专利网。