[发明专利]全局唯一标识生成方法、设备以及计算机可读存储介质有效
申请号: | 202010936028.1 | 申请日: | 2020-09-08 |
公开(公告)号: | CN112073554B | 公开(公告)日: | 2023-04-18 |
发明(设计)人: | 韩时通 | 申请(专利权)人: | 腾讯科技(深圳)有限公司 |
主分类号: | H04L41/0894 | 分类号: | H04L41/0894;H04L41/0853 |
代理公司: | 广州三环专利商标代理有限公司 44202 | 代理人: | 熊永强;杜维 |
地址: | 518057 广东省深圳*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 全局 唯一 标识 生成 方法 设备 以及 计算机 可读 存储 介质 | ||
1.一种全局唯一标识生成方法,其特征在于,包括:
标识生成进程查询关系数据库中的工作标识记录表,若查询出未被写入表中的工作标识,则将此工作标识确定为可用工作标识;
标识生成进程请求将所述可用工作标识写入所述关系数据库中的工作标识记录表;
若成功将所述可用工作标识写入所述关系数据库中的工作标识记录表,所述标识生成进程则将所述可用工作标识保存至所述标识生成进程的全局变量中;
所述标识生成进程运用Snowflake雪花算法,调用全局变量中记录的目标标识生成全局唯一标识。
2.根据权利要求1所述的方法,其特征在于,所述方法还包括:
若将所述可用工作标识写入所述关系数据库中的工作标识记录表失败,所述标识生成进程则重新查询关系数据库中的工作标识记录表,并根据查询结果重新确定可用工作标识。
3.根据权利要求1所述的方法,其特征在于,所述方法还包括:
若根据查询结果确定无可用工作标识,所述标识生成进程则向配置中心请求在所述配置中心记录的所有进程服务地址,通过访问所述进程服务地址,确定当前服务状态为不可用的第一标识生成进程;
将所述服务状态为不可用的第一标识生成进程中占用的工作标识作为可用工作标识保存至所述标识生成进程的全局变量中。
4.根据权利要求1所述的方法,其特征在于,所述标识生成进程根据所述全局变量生成全局唯一标识之前,所述方法还包括:
若成功将所述可用工作标识写入所述关系数据库中的工作标识记录表,则所述标识生成进程向配置中心发送服务注册请求,所述服务注册请求携带进程服务地址,所述服务注册请求用于请求所述配置中心记录所述标识生成进程的进程服务地址,所述进程服务地址用于访问所述标识生成进程;
所述标识生成进程根据所述全局变量中的可用工作标识生成全局唯一标识包括:
所述标识生成进程接受业务进程根据所述配置中心记录的进程服务地址发送的业务标识请求,所述标识生成进程根据所述全局变量中的可用工作标识生成全局唯一标识,并将生成得到的全局唯一标识返回至所述业务进程。
5.根据权利要求4所述的方法,其特征在于,所述进程服务地址为所述业务进程通过向所述配置中心发送进程服务地址请求后,从所述配置中心得到的。
6.根据权利要求4所述的方法,其特征在于,所述业务标识请求为所述配置中心在接收到所述业务进程发送的业务标识请求后,根据其记录的所述进程服务地址向所述标识生成进程转发的。
7.一种全局唯一标识生成装置,其特征在于,包括:
标识查询模块,用于通过标识生成进程查询关系数据库中的工作标识记录表;
标识确定模块,用于根据所述标识查询模块的查询结果确定可用的工作标识;
标识写入模块,用于通过标识生成进程请求将所述标识确定模块确定的所述可用工作标识写入所述关系数据库中的工作标识记录表;
标识保存模块,用于在所述标识写入模块成功将所述可用工作标识写入所述关系数据库中的工作标识记录表时,通过所述标识生成进程将所述可用工作标识保存至所述标识生成进程的全局变量中;
标识生成模块,用于通过所述标识生成进程根据所述全局变量中的可用工作标识生成全局唯一标识。
8.一种全局唯一标识生成设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1至6任一项所述的方法的步骤。
9.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1-6任一项所述的方法的步骤。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于腾讯科技(深圳)有限公司,未经腾讯科技(深圳)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202010936028.1/1.html,转载请声明来源钻瓜专利网。