[发明专利]一种适用于微服务系统的数据库主键生成方法在审
申请号: | 202111282607.X | 申请日: | 2021-11-01 |
公开(公告)号: | CN113946586A | 公开(公告)日: | 2022-01-18 |
发明(设计)人: | 王巧;周光勇;陈虎;邹平 | 申请(专利权)人: | 重庆忽米网络科技有限公司 |
主分类号: | G06F16/22 | 分类号: | G06F16/22;G06F16/2458 |
代理公司: | 重庆博凯知识产权代理有限公司 50212 | 代理人: | 黄河 |
地址: | 400041 重庆市高新*** | 国省代码: | 重庆;50 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 适用于 微服 系统 数据库 主键 生成 方法 | ||
本发明涉及数据库主键生成技术领域,具体涉及一种适用于微服务系统的数据库主键生成方法,包括:基于雪花算法创建对应的ID算法工具;创建Redis机器ID计算器,并利用Redis incr原子性生成唯一的机器ID;对ID算法工具进行初始化,然后基于唯一的机器ID设置ID算法工具的参数;在数据写入数据库时,通过ID算法工具生成唯一ID并进行赋值,然后将赋值后的唯一ID插入到数据库中作为对应的数据库主键。本发明中数据库主键生成方法能够保证主键性能和主键生成效率,从而提升数据库主键的生成效果。
技术领域
本发明涉及数据库主键生成技术领域,具体涉及一种适用于微服务系统的数据库主键生成方法。
背景技术
随着数据日益增长,业务数据量太大,单库单表不足以支撑现有业务,随之很多系统需要分布式部署,在此情况下对于数据库主键的生成需要满足全局唯一、高性能、好接入、高可用的条件。目前,数据库主键的生成方法主要包括数据库自增字段方法和GUID(全局统一标识符)方法。其中,自增字段方法由数据库自增类型字段来实现,由数据库自动生成和维护,并确保唯一性。GUID方法是利用机器硬件的唯一性特征(例如网卡MAC地址的唯一性)并结合生成时间,来确保在全球范围内不会出现重复的数值。
针对现有主键生成方法生成的数据库主键性能不足的问题,公开号为CN102880705B的中国专利公开了一种《数据库主键生成装置和数据库主键生成方法》,其装置包括:读取单元,读取预设的主键配置表,从主键配置表中获取数据中心的站点编号;主键生成单元,根据获取的站点编号读取主键分配表,获取主键分配表中记录的主键的最大值,根据主键的最大值得到当前可分配的主键的值,其中,主键包括数据中心的站点编号、生成主键的日期和流水号。
上述现有方案中的数据库主键生成方法生成的主键既具有像业务编号一样直观易用的特点,又可支持分布式数据部署环境。但是,现有数据库主键生成方法在应用于分布式环境下的微服务系统时,其主键的生成大多需要依赖于ID生成服务的远程调用,导致网络资源消耗严重,服务性能低下,进而导致数据库主键的生成效率很低。因此,如何设计一种能够保证主键性能和主键生成效率的数据库主键生成方法是亟需解决的技术问题。
发明内容
针对上述现有技术的不足,本发明所要解决的技术问题是:如何提供一种能够保证主键性能和主键生成效率的数据库主键生成方法,从而提升数据库主键的生成效果。
为了解决上述技术问题,本发明采用了如下的技术方案:
一种适用于微服务系统的数据库主键生成方法,包括以下步骤:
S1:基于雪花算法创建对应的ID算法工具;
S2:创建Redis机器ID计算器,并利用Redis incr原子性生成唯一的机器ID;
S3:对ID算法工具进行初始化,然后基于唯一的机器ID设置ID算法工具的参数;
S4:在数据写入数据库时,通过ID算法工具生成唯一ID并进行赋值,然后将赋值后的唯一ID插入到数据库中作为对应的数据库主键。
优选的,步骤S2中,通过如下步骤生成唯一的机器ID:
S201:获取对应的数据中心ID;
S202:获取对应的本机IP地址;
S203:通过设置的全局缓存前缀连接上数据中心ID,再连接上本机IP地址,进而获取对应的机器ID。
优选的,步骤S203中,若不存在预先缓存的机器ID,则执行incr命令生成一个增长ID,然后将该增长ID设置成键前缀,进而连接上数据中心ID,再连接上本机IP地址,最后将最终得到的ID作为此次的机器ID。
优选的,若未获取到对应的数据中心ID或本机IP地址,则停止机器ID的生成。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于重庆忽米网络科技有限公司,未经重庆忽米网络科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202111282607.X/2.html,转载请声明来源钻瓜专利网。