[发明专利]一种超大容量分布式数据库主键的生成算法在审
申请号: | 201811283046.3 | 申请日: | 2018-10-31 |
公开(公告)号: | CN109299075A | 公开(公告)日: | 2019-02-01 |
发明(设计)人: | 俞禄;龚如伟 | 申请(专利权)人: | 上海萃颠信息科技有限公司 |
主分类号: | G06F16/21 | 分类号: | G06F16/21;G06F16/22;G06F16/2458 |
代理公司: | 暂无信息 | 代理人: | 暂无信息 |
地址: | 200030 上海市徐*** | 国省代码: | 上海;31 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 主键 分布式数据库 超大容量 机房 数据库主键 生成算法 合成 多主机 并发 流水 高性能算法 服务获得 全局管理 时间基线 时间前提 授时服务 配置 数据库 互联网 部署 应用 全球 | ||
本发明公开了一种超大容量分布式数据库主键的生成算法,合成主键的步骤如下所示;S1:通过全球授时服务获得当前时间自时间基线运行的毫秒数;S2:确定当前时间前提下,通过配置获得当前机器所在机房号;S3:通过配置获得当前机器的机器号;S4:经过S1‑S3的操作步骤,通过流水服务获得当前流水;S5:合成1‑4步获得数据,合成主键。本发明操作方法简单,生成支持高并发超大容量分布式数据库的主键。可广泛应用于目前大型互联网中,本发明能在全局管理数据库主键生成的方法,可以很好的实现在多地多机房多主机的分布式数据库中采用一种高性能算法,实现高性能的,大并发的数据库主键生成,满足现在数据库多地多机房多主机分布式的部署方式。
技术领域
本发明涉及一种超大容量分布式数据库主键的生成算法,属于软件开发技术领域。
背景技术
目前互联网应用中数据存储量是海量的,为了提升数据访问效率及安全性的考虑,数据库基本都是分多地多机房部署,这对数据库表的主键设计提出了很高的要求,不但要求数据库主键能适应大并发的性能要求,而且需要考虑数据库迁移、合并变更以及查询效率等诸多需求。
目前一般采用的主键技术有2种,一种是利用数据库自增技术,优点是技术简单,主键自增,具有趋势性,查询时作为索引效率高。缺点是每秒的最大并发数有限制,并且迁移合并会遇到主键重复的问题。
第二种方式是采用UUID的方式。这种方式的优点是主键不会重复,基本没有性能问题,数据库的合并、迁移也没有问题,但由于产生的主键是字符串,没有排序,无法保证趋势递增,所有在查询时效率很低。
应此一个能综合自增主键和UUID主键方式优点,并避免以上两种产生主键方式缺点的数据库主键的算法,具有极大经济效益和社会效益。
发明内容
本发明的目的在于:针对以上现有技术存在的不足,提出超大容量分布式数据库主键的生成算法,从技术原理上解决这一问题。
为了解决上述技术问题,本发明提供了如下的技术方案:
本发明提供一种超大容量分布式数据库主键的生成算法,合成主键的步骤如下所示;
S1:通过全球授时服务获得当前时间自时间基线运行的毫秒数;确定数据产生的时间段;
S2:确定当前时间前提下,通过配置获得当前机器所在机房号;确定数据产生的地址;
S3:通过配置获得当前机器的机器号;确定数据产生的具体用户端;
S4:经过S1-S3的操作步骤,通过流水服务获得当前流水;可确定当前数据的目的,可对其进行分类处理;
S5:合成1-4步获得数据,合成主键。
作为本发明的一种优选技术方案,主键生成算法的返回值采用long类型。
作为本发明的一种优选技术方案,所述主键由41位毫秒数、N位机房数、M位机器数和I位流水构成;其中41位毫秒数是受操作系统指定的,而对应的机房数、机器数和流水的位数可根据实际操作进行取值。
作为本发明的一种优选技术方案,N=4,M=4,I=4。
本发明所达到的有益效果是:本发明操作方法简单,生成支持高并发超大容量分布式数据库的主键。可广泛应用于目前大型互联网中,本发明能在全局管理数据库主键生成的方法,可以很好的实现在多地多机房多主机的分布式数据库中采用一种高性能算法,实现高性能的,大并发的数据库主键生成,满足现在数据库多地多机房多主机分布式的部署方式。
附图说明
附图用来提供对本发明的进一步理解,并且构成说明书的一部分,与本发明的实施例一起用于解释本发明,并不构成对本发明的限制。
在附图中:
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于上海萃颠信息科技有限公司,未经上海萃颠信息科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201811283046.3/2.html,转载请声明来源钻瓜专利网。