CN111538594A - 基于分布式***的订单id生成方法、装置、设备及介质 - Google Patents

基于分布式***的订单id生成方法、装置、设备及介质 Download PDF

Info

Publication number
CN111538594A
CN111538594A CN202010319510.0A CN202010319510A CN111538594A CN 111538594 A CN111538594 A CN 111538594A CN 202010319510 A CN202010319510 A CN 202010319510A CN 111538594 A CN111538594 A CN 111538594A
Authority
CN
China
Prior art keywords
order
generated
node server
primary key
distributed system
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN202010319510.0A
Other languages
English (en)
Other versions
CN111538594B (zh
Inventor
安磊
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
China Merchants Finance Technology Co Ltd
Original Assignee
China Merchants Finance Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by China Merchants Finance Technology Co Ltd filed Critical China Merchants Finance Technology Co Ltd
Priority to CN202010319510.0A priority Critical patent/CN111538594B/zh
Publication of CN111538594A publication Critical patent/CN111538594A/zh
Application granted granted Critical
Publication of CN111538594B publication Critical patent/CN111538594B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5027Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5083Techniques for rebalancing the load in a distributed system
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • H04L67/1001Protocols in which an application is distributed across nodes in the network for accessing one among a plurality of replicated servers
    • H04L67/1004Server selection for load balancing
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02PCLIMATE CHANGE MITIGATION TECHNOLOGIES IN THE PRODUCTION OR PROCESSING OF GOODS
    • Y02P90/00Enabling technologies with a potential contribution to greenhouse gas [GHG] emissions mitigation
    • Y02P90/30Computing systems specially adapted for manufacturing

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本发明涉及云服务技术领域,揭露了一种基于分布式***的订单ID生成方法,包括:获取分布式***中所有的节点服务器;利用预设自增序列算法分配所述节点服务器的ID主键;记录所述节点服务器中所有待生成订单的ID生成时间戳,并确定所述节点服务器中所有待生成订单的ID序列号;根据所述节点服务器的ID主键、所述待生成订单的ID生成时间戳以及所述待生成订单的ID序列号,及利用预设ID生成器编译并生成所述待生成订单的ID。本发明还提出一种基于分布式***的订单ID生成装置、电子设备以及计算机可读存储介质。本发明可以解决在基于分布式***的订单ID生成时出现ID碰撞的现象。

Description

基于分布式***的订单ID生成方法、装置、设备及介质
技术领域
本发明涉及云服务技术领域,尤其涉及一种基于分布式***的订单ID生成的方法、装置、电子设备及计算机可读存储介质。
背景技术
分布式***指的是多个节点通过网络连接在一起并通过消息的传递来进行协调的***。所述节点包括数据库节点、网络节点以及处理机节点等等。通常来说,节点指的是将一个软/硬件部署在服务器中,该服务器即为对应的软/硬件节点,例如,每一台连上网络服务器的计算机就是一个网络节点。
目前关于分布式***中多节点的订单ID生成通常是基于squence算法,但通过squence算法生成分布式***中多节点的订单ID时,通常会发生订单ID重复的现象,从而导致订单ID产生碰撞。
发明内容
本发明提供一种基于分布式***的订单ID生成的方法、装置、电子设备及计算机可读存储介质,其主要目的在于解决在基于分布式***的订单ID生成时出现ID碰撞的现象,提高分布式***性能。
为实现上述目的,本发明提供的一种基于分布式***的订单ID生成方法,包括:
获取分布式***中所有的节点服务器;
利用预设自增序列算法分配所述节点服务器的ID主键;
记录所述节点服务器中所有待生成订单的ID生成时间戳,并确定所述节点服务器中所有待生成订单的ID序列号;
根据所述节点服务器的ID主键、所述待生成订单的ID生成时间戳以及所述待生成订单的ID序列号,及利用预设ID生成器编译并生成所述待生成订单的ID。
可选地,所述利用预设自增序列算法分配所述节点服务器的ID主键,包括:
配置所述节点服务器的ID主键编译环境;
将预设的ID主键生成jar包导入至所述ID主键编译环境中;
初始化所述节点服务器的ID主键;
对初始化后的节点服务器的ID主键进行加一操作后运行所述jar包,生成所述节点服务器的ID主键。
可选地,所述记录所述节点服务器中所有待生成订单的ID生成时间戳,并确定所述节点服务器中所有待生成订单的ID序列号,包括:
通过预设的时间序列长度记录所述节点服务器的ID生成时间戳,及通过预设ID序列长度生成所述节点服务器的ID序列号。
可选地,所述根据所述节点服务器的ID主键、所述待生成订单的ID生成时间戳以及所述待生成订单的ID序列号,及利用预设ID生成器编译并生成所述待生成订单的ID,包括:
根据所述节点服务器的ID主键、所述待生成订单的ID生成时间戳以及所述待生成订单的ID序列号,获取所述节点服务器中所有待生成订单的ID标识位数;
配置所述节点服务器的订单ID生成编译环境,将所述ID标识位数导入至所述订单ID生成编译环境中;
利用所述预设ID生成器编译所述ID标识位数,得到订单ID生成的源程序代码包,运行所述源程序代码包,生成所述待生成订单的ID。
可选地,在生成所述待生成订单的ID之后,该方法还包括:
将所述待生成订单的ID存入预设缓存中,并设置所述预设缓存中待生成订单的ID有效时间,根据所述有效时间,删除对应的订单ID。
为了解决上述问题,本发明还提供一种基于分布式***的订单ID生成装置,所述装置包括:
获取模块,用于获取分布式***中所有的节点服务器;
分配模块,用于利用预设自增序列算法分配所述节点服务器的ID主键;
记录及确定模块,用于记录所述节点服务器中所有待生成订单的ID生成时间戳,并确定所述节点服务器中所有待生成订单的ID序列号;
生成模块,用于根据所述节点服务器的ID主键、所述待生成订单的ID生成时间戳以及所述待生成订单的ID序列号,及利用预设ID生成器编译并生成所述待生成订单的ID。
可选地,所述分配模块包括:
配置及导入子模块:用于配置所述节点服务器的ID主键编译环境,将预设的ID主键生成jar包导入至所述ID主键编译环境中;
初始化及运行子模块:用于初始化所述节点服务器的ID主键,对初始化后的节点服务器的ID主键进行加一操作后运行所述jar包,生成所述节点服务器的ID主键。
可选地,所述生成模块包括:
获取及配置子模块:用于根据所述节点服务器的ID主键、所述待生成订单的ID生成时间戳以及所述待生成订单的ID序列号,获取所述节点服务器中所有待生成订单的ID标识位数,配置所述节点服务器的订单ID生成编译环境,将所述ID标识位数导入至所述订单ID生成编译环境中;
编译及运行子模块:用于利用所述预设ID生成器编译所述ID标识位数,得到订单ID生成的源程序代码包,运行所述源程序代码包,生成所述待生成订单的ID。
为了解决上述问题,本发明还提供一种电子设备,所述电子设备包括:
存储器,存储至少一个指令;及
处理器,执行所述存储器中存储的指令以实现上述中所述的基于分布式***的订单ID生成方法。
为了解决上述问题,本发明还提供一种计算机可读存储介质,所述计算机可读存储介质中存储有至少一个指令,所述至少一个指令被电子设备中的处理器执行以实现上述中所述的基于分布式***的订单ID生成方法。
本发明实施例获取分布式***中所有的节点服务器,利用预设自增序列算法分配所述节点服务器的ID主键,通过分配的ID主键可以确定节点服务器的全局唯一性,从而可以保证在节点服务器中生成的ID唯一性,进而避免了后续节点服务器中订单ID生成时出现乱撞的现象;进一步地,部署所述节点服务器中所有待生成订单的ID生成时间戳,并确定所述节点服务器中所有待生成订单的ID序列号,结合所述ID主键、所述ID生成时间戳以及所述ID序列号,并利用预设ID生成器编译并生成所述待生成订单的ID。因此,本发明提出的一种基于分布式***的订单ID生成方法、装置、电子设备以及计算机可读存储介质可以解决在基于分布式***的订单ID生成时出现ID碰撞的现象,提高分布式***性能。
附图说明
图1为本发明一实施例提供的基于分布式***的订单ID生成方法的流程示意图;
图2为本发明图1中文本特征语义提取方法中步骤S4的详细实施流程示意图;
图3为本发明一实施例提供的基于分布式***的订单ID生成装置的模块示意图;
图4为本发明一实施例提供的实现基于分布式***的订单ID生成方法的电子设备的内部结构示意图;
本发明目的的实现、功能特点及优点将整合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
本发明提供一种基于分布式***的订单ID生成的方法。参照图1所示,为本发明一实施例提供的基于分布式***的订单ID生成方法的流程示意图。该方法可以由一个装置执行,该装置可以由软件和/或硬件实现。
在本实施例中,基于分布式***的订单ID生成的方法包括:
S1、获取分布式***中所有的节点服务器。
在本发明的至少一个实施例中,所述分布式***基于不同用户需求而创建,并由服务器(以下称为节点服务器)、数据库以及路由等等硬件设备所组成。
一个可选实施例中,所述分布式***可以为商城订单***,其包含订单创建子***、订单修改子***、订单发送子***以及订单接收子***等。在所述商城订单***中,其包含的各个子***可以安装在不同的节点服务器中,通过所述不同的节点服务器之间的网络连接,实现子***之间的相互通信运作。
进一步地,本发明实施例中所述的分布式***可以利用不同的节点服务器处理不同的用户需求,例如某用户的需求为创建一个订单,则本发明实施例将所述订单创建任务分配给其中一个节点服务器,所述节点服务器根据所述用户的需求执行订单创建,包括:获取该订单的jar包,与后台数据库进行交互,得到该订单的序列号,将所述序列号返回至前端页面中,实现订单的创建。
进一步地,本发明实施例获取所述分布式***中部署的所有节点服务器,并利用反向代理实现所述分布式***中每个节点服务器的均衡负载,即每个节点服务器需要执行的任务量是一致的,以加快用户请求的处理,并实现分布式***的资源服务均衡。
S2、利用预设自增序列算法分配所述节点服务器的ID主键。
所述ID主键又称nodeID,通过所述ID主键可以标识节点服务器在分布式***中的唯一性。
较佳地,本发明实施例所述预设自增序列算法包括redis自增序列算法。
详细地,所述利用预设自增序列算法分配所述节点服务器的ID主键,包括:
配置所述节点服务器的ID主键编译环境,将预设的ID主键生成jar包导入至所述ID主键编译环境中,初始化所述节点服务器的ID主键,利用Redis Incr命令对初始化后的节点服务器的ID主键进行key值加一操作后运行所述jar包,生成所述节点服务器的ID主键。
可选的,本发明实施例可以利用Java编程语言配置所述节点服务器的ID主键编译环境。
可选的,所述预设的ID主键jar包通过java语言编译生成。
进一步地,本发明实施例在利用预设自增序列算法分配所述节点服务器的ID主键之后,还包括:将所述ID主键存入本地缓存中,通过直接查询本地缓存的ID主键,可以避免过多的与后台数据库的交互次数,提高分布式***的性能,以及减少后续节点服务器ID主键的查询时间。
在本发明的至少一个实施例中,通过预设自增序列算法分配所述节点服务器的ID主键,实现了所述节点服务器在分布式***的唯一性,从而可以保障后续在不同节点服务器中生成的订单ID全局唯一性。
S3、记录所述节点服务器中所有待生成订单的ID生成时间戳,并确定所述节点服务器中所有待生成订单的ID序列号。
在本发明的至少一个实施例中可以利用雪花算法结构中的41位毫秒级时间序列长度记录所述节点服务器中所有待生成订单的ID生成时间戳,并利用所述雪花算法结构中的12位ID序列长度确定所述节点服务器中所有待生成订单的ID序列号。
所述ID生成时间戳指的是ID生成结束时间戳与ID生成开始时间戳的差值。
所述ID序列号指的是待生成订单的订单号,可以确定节点服务器的产生订单ID数量。
所述雪花算法包括:1位最高位标识符、41位毫秒级时间序列长度、5位数据中心标识长度、5为服务器标识长度以及12位ID序列长度。
S4、根据所述节点服务器的ID主键、所述待生成订单的ID生成时间戳以及所述待生成订单的ID序列号,及利用预设ID生成器编译并生成所述待生成订单的ID。
详细的,参阅图2所示,所述根据所述ID主键、所述ID生成时间戳以及所述ID序列号,及利用预设ID生成器编译所述节点服务器的ID,生成ID包括:
S40、根据所述节点服务器的ID主键、所述待生成订单的ID生成时间戳以及所述待生成订单的ID序列号,获取所述节点服务器中所有待生成订单的ID标识位数。
可选的,所述ID标识位数包括数据中心的占用位数、序列号的占用位数以及机器的占用位数。所述数据中心指的是与所述节点服务器相交互的数据库,所述机器指的是运行对应节点服务器所要执行任务的载体。
S41、配置所述节点服务器的订单ID生成编译环境,将所述ID标识位数导入至所述订单ID生成编译环境中。
较佳地,本发明实施例通过java编程语言配置所述节点服务器的ID生成编译环境,并利用get()方法将所述ID标识位数导入至所述ID生成环境中。
S42、利用所述预设ID生成器编译所述ID标识位数,得到订单ID生成的源程序代码包,运行所述源程序代码包,生成所述待生成订单的ID。
可选的,所述预设ID生成器通过java编程语言进行编译得到。
在本发明的另一个实施例中,在生成所述待生成订单的ID之后,还包括:将所述待生成订单的ID存入redis缓存中,并设置所述redis缓存中待生成订单的ID有效时间,根据所述有效时间,删除对应的订单ID,以支持分布式***的高并发性。
本发明实施例获取分布式***中所有的节点服务器,利用预设自增序列算法分配所述节点服务器的ID主键,通过分配的ID主键可以确定节点服务器的全局唯一性,从而可以保证在节点服务器中生成的ID唯一性,进而避免了后续节点服务器中订单ID生成时出现乱撞的现象;进一步地,部署所述节点服务器中所有待生成订单的ID生成时间戳,并确定所述节点服务器中所有待生成订单的ID序列号,结合所述ID主键、所述ID生成时间戳以及所述ID序列号,并利用预设ID生成器编译并生成所述待生成订单的ID。因此,本发明提出的一种基于分布式***的订单ID生成方法可以解决在基于分布式***的订单ID生成ID时出现ID碰撞的现象,提高分布式***性能。
如图3所示,是本发明一实施例提供的基于分布式***的订单ID生成装置的模块示意图。
本发明所述基于分布式***的订单ID生成装置100可以安装于电子设备中。根据实现的功能,所述基于分布式***的订单ID生成装置可以包括获取模块101、分配模块102、记录及确定模块103以及生成模块104。本发明所述模块也可以称之为单元,是指一种能够被电子设备处理器所执行,并且能够完成固定功能的一系列计算机程序段,其存储在电子设备的存储器中。
在本实施例中,关于各模块/单元的功能如下:
所述获取模块101,用于获取分布式***中所有的节点服务器。
所述ID主键又称nodeID,通过所述ID主键可以标识节点服务器在分布式***中的唯一性。
较佳地,本发明实施例所述预设自增序列算法包括redis自增序列算法。
详细地,所述利用预设自增序列算法分配所述节点服务器的ID主键,包括:
配置所述节点服务器的ID主键编译环境,将预设的ID主键生成jar包导入至所述ID主键编译环境中,初始化所述节点服务器的ID主键,利用Redis Incr命令对初始化后的节点服务器的ID主键进行key值加一操作后运行所述jar包,生成所述节点服务器的ID主键。
可选的,本发明实施例可以利用Java编程语言配置所述节点服务器的ID主键编译环境。
可选的,所述预设的ID主键jar包通过java语言编译生成。
进一步地,本发明实施例在利用预设自增序列算法分配所述节点服务器的ID主键之后,还包括:将所述ID主键存入本地缓存中,通过直接查询本地缓存的ID主键,可以避免过多的与后台数据库的交互次数,提高分布式***的性能,以及减少后续节点服务器ID主键的查询时间。
在本发明的至少一个实施例中,通过预设自增序列算法分配所述节点服务器的ID主键,实现了所述节点服务器在分布式***的唯一性,从而可以保障后续在不同节点服务器中生成的订单ID全局唯一性。
所述分配模块102,用于利用预设自增序列算法分配所述节点服务器的ID主键。
所述ID主键又称nodeID,通过所述ID主键可以标识节点服务器在分布式***中的唯一性。
较佳地,本发明实施例所述预设自增序列算法包括redis自增序列算法。
详细地,所述利用预设自增序列算法分配所述节点服务器的ID主键,包括:
配置及导入子模块1020:用于配置所述节点服务器的ID主键编译环境,将预设的ID主键生成jar包导入至所述ID主键编译环境中。
初始化及运行子模块1021:用于初始化所述节点服务器的ID主键,对初始化后的节点服务器的ID主键进行key值加一操作后运行所述jar包,生成所述节点服务器的ID主键。
可选的,本发明实施例可以利用Java编程语言配置所述节点服务器的ID主键编译环境。
可选的,所述预设的ID主键jar包通过java语言编译生成。
进一步地,本发明实施例在利用预设自增序列算法分配所述节点服务器的ID主键之后,还包括:将所述ID主键存入本地缓存中,通过直接查询本地缓存的ID主键,可以避免过多的与后台数据库的交互次数,提高分布式***的性能,以及减少后续节点服务器ID主键的查询时间。
在本发明的至少一个实施例中,通过预设自增序列算法分配所述节点服务器的ID主键,实现了所述节点服务器在分布式***的唯一性,从而可以保障后续在不同节点服务器中生成的订单ID全局唯一性。
所述记录及确定模块103,用于记录所述节点服务器中所有待生成订单的ID生成时间戳,并确定所述节点服务器中所有待生成订单的ID序列号。
在本发明的至少一个实施例中可以利用雪花算法结构中的41位毫秒级时间序列长度记录所述节点服务器中所有待生成订单的ID生成时间戳,并利用所述雪花算法结构中的12位ID序列长度确定所述节点服务器中所有待生成订单的ID序列号。
所述ID生成时间戳指的是ID生成结束时间戳与ID生成开始时间戳的差值。
所述ID序列号指的是待生成订单的订单号,可以确定节点服务器的产生订单ID数量。
所述雪花算法包括:1位最高位标识符、41位毫秒级时间序列长度、5位数据中心标识长度、5为服务器标识长度以及12位ID序列长度。
所述生成模块104,用于根据所述节点服务器的ID主键、所述待生成订单的ID生成时间戳以及所述待生成订单的ID序列号,及利用预设ID生成器编译并生成所述待生成订单的ID。
详细的,所述根据所述ID主键、所述ID生成时间戳以及所述ID序列号,及利用预设ID生成器编译所述节点服务器的ID,生成ID包括:
获取及配置子模块1040:用于根据所述节点服务器的ID主键、所述待生成订单的ID生成时间戳以及所述待生成订单的ID序列号,获取所述节点服务器中所有待生成订单的ID标识位数,配置所述节点服务器的订单ID生成编译环境,将所述ID标识位数导入至所述订单ID生成编译环境中。
可选的,所述ID标识位数包括数据中心的占用位数、序列号的占用位数以及机器的占用位数。所述数据中心指的是与所述节点服务器相交互的数据库,所述机器指的是运行对应节点服务器所要执行任务的载体。
较佳地,本发明实施例通过java编程语言配置所述节点服务器的ID生成编译环境,并利用get()方法将所述ID标识位数导入至所述ID生成环境中。
编译及运行子模块1041:用于利用所述预设ID生成器编译所述ID标识位数,得到订单ID生成的源程序代码包,运行所述源程序代码包,生成所述待生成订单的ID。
可选的,所述预设ID生成器通过java编程语言进行编译得到。
在本发明的另一个实施例中,在生成所述待生成订单的ID之后,还包括:将所述待生成订单的ID存入redis缓存中,并设置所述redis缓存中待生成订单的ID有效时间,根据所述有效时间,删除对应的订单ID,以支持分布式***的高并发性。
本发明实施例获取分布式***中所有的节点服务器,利用预设自增序列算法分配所述节点服务器的ID主键,通过分配的ID主键可以确定节点服务器的全局唯一性,从而可以保证在节点服务器中生成的ID唯一性,进而避免了后续节点服务器中订单ID生成时出现乱撞的现象;进一步地,部署所述节点服务器中所有待生成订单的ID生成时间戳,并确定所述节点服务器中所有待生成订单的ID序列号,结合所述ID主键、所述ID生成时间戳以及所述ID序列号,并利用预设ID生成器编译并生成所述待生成订单的ID。因此,本发明提出的一种基于分布式***的订单ID生成装置可以解决在基于分布式***的订单ID生成ID时出现ID碰撞的现象,提高分布式***性能。
如图4所示,是本发明一实施例提供的实现基于分布式***的订单ID生成的方法的电子设备的结构示意图。
所述电子设备1可以包括处理器10、存储器11和总线,还可以包括存储在所述存储器11中并可在所述处理器10上运行的计算机程序,如基于分布式***的订单ID生成程序。
其中,所述存储器11至少包括一种类型的可读存储介质,所述可读存储介质包括闪存、移动硬盘、多媒体卡、卡型存储器(例如:SD或DX存储器等)、磁性存储器、磁盘、光盘等。所述存储器11在一些实施例中可以是电子设备1的内部存储单元,例如该电子设备1的移动硬盘。所述存储器11在另一些实施例中也可以是电子设备1的外部存储设备,例如电子设备1上配备的插接式移动硬盘、智能存储卡(Smart Media Card,SMC)、安全数字(SecureDigital,SD)卡、闪存卡(Flash Card)等。进一步地,所述存储器11还可以既包括电子设备1的内部存储单元也包括外部存储设备。所述存储器11不仅可以用于存储安装于电子设备1的应用软件及各类数据,例如基于分布式***的订单ID生成程序的代码等,还可以用于暂时地存储已经输出或者将要输出的数据。
所述处理器10在一些实施例中可以由集成电路组成,例如可以由单个封装的集成电路所组成,也可以是由多个相同功能或不同功能封装的集成电路所组成,包括一个或者多个中央处理器(Central Processing unit,CPU)、微处理器、数字处理芯片、图形处理器及各种控制芯片的组合等。所述处理器10是所述电子设备的控制核心(Control Unit),利用各种接口和线路连接整个电子设备的各个部件,通过运行或执行存储在所述存储器11内的程序或者模块(例如基于分布式***的订单ID生成程序等),以及调用存储在所述存储器11内的数据,以执行电子设备1的各种功能和处理数据。
所述总线可以是外设部件互连标准(peripheral component interconnect,简称PCI)总线或扩展工业标准结构(extended industry standard architecture,简称EISA)总线等。该总线可以分为地址总线、数据总线、控制总线等。所述总线被设置为实现所述存储器11以及至少一个处理器10等之间的连接通信。
图4仅示出了具有部件的电子设备,本领域技术人员可以理解的是,图4示出的结构并不构成对所述电子设备1的限定,可以包括比图示更少或者更多的部件,或者组合某些部件,或者不同的部件布置。
例如,尽管未示出,所述电子设备1还可以包括给各个部件供电的电源(比如电池),优选地,电源可以通过电源管理装置与所述至少一个处理器10逻辑相连,从而通过电源管理装置实现充电管理、放电管理、以及功耗管理等功能。电源还可以包括一个或一个以上的直流或交流电源、再充电装置、电源故障检测电路、电源转换器或者逆变器、电源状态指示器等任意组件。所述电子设备1还可以包括多种传感器、蓝牙模块、Wi-Fi模块等,在此不再赘述。
进一步地,所述电子设备1还可以包括网络接口,可选地,所述网络接口可以包括有线接口和/或无线接口(如WI-FI接口、蓝牙接口等),通常用于在该电子设备1与其他电子设备之间建立通信连接。
可选地,该电子设备1还可以包括用户接口,用户接口可以是显示器(Display)、输入单元(比如键盘(Keyboard)),可选地,用户接口还可以是标准的有线接口、无线接口。可选地,在一些实施例中,显示器可以是LED显示器、液晶显示器、触控式液晶显示器以及OLED(Organic Light-Emitting Diode,有机发光二极管)触摸器等。其中,显示器也可以适当的称为显示屏或显示单元,用于显示在电子设备1中处理的信息以及用于显示可视化的用户界面。
应该了解,所述实施例仅为说明之用,在专利申请范围上并不受此结构的限制。
所述电子设备1中的所述存储器11存储的基于分布式***的订单ID生成程序12是多个指令的组合,在所述处理器10中运行时,可以实现:
获取分布式***中所有的节点服务器;
利用预设自增序列算法分配所述节点服务器的ID主键;
记录所述节点服务器中所有待生成订单的ID生成时间戳,并确定所述节点服务器中所有待生成订单的ID序列号;
根据所述节点服务器的ID主键、所述待生成订单的ID生成时间戳以及所述待生成订单的ID序列号,及利用预设ID生成器编译并生成所述待生成订单的ID。
具体地,所述处理器10对上述指令的具体实现方法可参考图1对应实施例中相关步骤的描述,在此不赘述。
进一步地,所述电子设备1集成的模块/单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。所述计算机可读介质可以包括:能够携带所述计算机程序代码的任何实体或装置、记录介质、U盘、移动硬盘、磁碟、光盘、计算机存储器、只读存储器(ROM,Read-Only Memory)。
在本发明所提供的几个实施例中,应该理解到,所揭露的设备,装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述模块的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式。
所述作为分离部件说明的模块可以是或者也可以不是物理上分开的,作为模块显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部模块来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能模块的形式实现。
对于本领域技术人员而言,显然本发明不限于上述示范性实施例的细节,而且在不背离本发明的精神或基本特征的情况下,能够以其他的具体形式实现本发明。
因此,无论从哪一点来看,均应将实施例看作是示范性的,而且是非限制性的,本发明的范围由所附权利要求而不是上述说明限定,因此旨在将落在权利要求的等同要件的含义和范围内的所有变化涵括在本发明内。不应将权利要求中的任何附关联图标记视为限制所涉及的权利要求。
此外,显然“包括”一词不排除其他单元或步骤,单数不排除复数。***权利要求中陈述的多个单元或装置也可以由一个单元或装置通过软件或者硬件来实现。第二等词语用来表示名称,而并不表示任何特定的顺序。
最后应说明的是,以上实施例仅用以说明本发明的技术方案而非限制,尽管参照较佳实施例对本发明进行了详细说明,本领域的普通技术人员应当理解,可以对本发明的技术方案进行修改或等同替换,而不脱离本发明技术方案的精神和范围。

Claims (10)

1.一种基于分布式***的订单ID生成方法,其特征在于,所述方法包括:
获取分布式***中所有的节点服务器;
利用预设自增序列算法分配所述节点服务器的ID主键;
记录所述节点服务器中所有待生成订单的ID生成时间戳,并确定所述节点服务器中所有待生成订单的ID序列号;
根据所述节点服务器的ID主键、所述待生成订单的ID生成时间戳以及所述待生成订单的ID序列号,及利用预设ID生成器编译并生成所述待生成订单的ID。
2.如权利要求1所述的基于分布式***的订单ID生成方法,其特征在于,所述利用预设自增序列算法分配所述节点服务器的ID主键,包括:
配置所述节点服务器的ID主键编译环境;
将预设的ID主键生成jar包导入至所述ID主键编译环境中;
初始化所述节点服务器的ID主键;
对初始化后的节点服务器的ID主键进行加一操作后运行所述jar包,生成所述节点服务器的ID主键。
3.如权利要求1所述的基于分布式***的订单ID生成方法,其特征在于,所述记录所述节点服务器中所有待生成订单的ID生成时间戳,并确定所述节点服务器中所有待生成订单的ID序列号,包括:
通过预设的时间序列长度记录所述节点服务器的ID生成时间戳,及通过预设ID序列长度生成所述节点服务器的ID序列号。
4.如权利要求1所述的基于分布式***的订单ID生成方法,其特征在于,所述根据所述节点服务器的ID主键、所述待生成订单的ID生成时间戳以及所述待生成订单的ID序列号,及利用预设ID生成器编译并生成所述待生成订单的ID,包括:
根据所述节点服务器的ID主键、所述待生成订单的ID生成时间戳以及所述待生成订单的ID序列号,获取所述节点服务器中所有待生成订单的ID标识位数;
配置所述节点服务器的订单ID生成编译环境,将所述ID标识位数导入至所述订单ID生成编译环境中;
利用所述预设ID生成器编译所述ID标识位数,得到订单ID生成的源程序代码包,运行所述源程序代码包,生成所述待生成订单的ID。
5.如权利要求1至4中任意一项所述的基于分布式***的订单ID生成方法,其特征在于,在生成所述待生成订单的ID之后,该方法还包括:
将所述待生成订单的ID存入预设缓存中,并设置所述预设缓存中待生成订单的ID有效时间,根据所述有效时间,删除对应的订单ID。
6.一种基于分布式***的订单ID生成装置,其特征在于,所述装置包括:
获取模块,用于获取分布式***中所有的节点服务器;
分配模块,用于利用预设自增序列算法分配所述节点服务器的ID主键;
记录及确定模块,用于记录所述节点服务器中所有待生成订单的ID生成时间戳,并确定所述节点服务器中所有待生成订单的ID序列号;
生成模块,用于根据所述节点服务器的ID主键、所述待生成订单的ID生成时间戳以及所述待生成订单的ID序列号,及利用预设ID生成器编译并生成所述待生成订单的ID。
7.如权利要求6所述的基于分布式***的订单ID生成装置,其特征在于,所述分配模块包括:
配置及导入子模块:用于配置所述节点服务器的ID主键编译环境,将预设的ID主键生成jar包导入至所述ID主键编译环境中;
初始化及运行子模块:用于初始化所述节点服务器的ID主键,对初始化后的节点服务器的ID主键进行加一操作后运行所述jar包,生成所述节点服务器的ID主键。
8.如权利要求6所述的基于分布式***的订单ID生成装置,其特征在于,所述生成模块包括:
获取及配置子模块:用于根据所述节点服务器的ID主键、所述待生成订单的ID生成时间戳以及所述待生成订单的ID序列号,获取所述节点服务器中所有待生成订单的ID标识位数,配置所述节点服务器的订单ID生成编译环境,将所述ID标识位数导入至所述订单ID生成编译环境中;
编译及运行子模块:用于利用所述预设ID生成器编译所述ID标识位数,得到订单ID生成的源程序代码包,运行所述源程序代码包,生成所述待生成订单的ID。
9.一种电子设备,其特征在于,所述电子设备包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行如权利要求1至5中任意一项所述的基于分布式***的订单ID生成方法。
10.一种计算机可读存储介质,存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至5中任意一项所述的基于分布式***的订单ID生成方法。
CN202010319510.0A 2020-04-21 2020-04-21 基于分布式***的订单id生成方法、装置、设备及介质 Active CN111538594B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202010319510.0A CN111538594B (zh) 2020-04-21 2020-04-21 基于分布式***的订单id生成方法、装置、设备及介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202010319510.0A CN111538594B (zh) 2020-04-21 2020-04-21 基于分布式***的订单id生成方法、装置、设备及介质

Publications (2)

Publication Number Publication Date
CN111538594A true CN111538594A (zh) 2020-08-14
CN111538594B CN111538594B (zh) 2023-04-18

Family

ID=71975150

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202010319510.0A Active CN111538594B (zh) 2020-04-21 2020-04-21 基于分布式***的订单id生成方法、装置、设备及介质

Country Status (1)

Country Link
CN (1) CN111538594B (zh)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112073554A (zh) * 2020-09-08 2020-12-11 腾讯科技(深圳)有限公司 全局唯一标识生成方法、设备以及计算机可读存储介质
CN112199083A (zh) * 2020-10-16 2021-01-08 深圳无域科技技术有限公司 基于表达式的可配置id生成***及方法
CN112202938A (zh) * 2020-10-12 2021-01-08 广州品唯软件有限公司 Id生成方法、装置及***
CN112667685A (zh) * 2020-12-29 2021-04-16 北京先进数通信息技术股份公司 一种流水号配置方法、装置、设备及存储介质
CN114723525A (zh) * 2022-04-08 2022-07-08 湖南快乐阳光互动娱乐传媒有限公司 一种订单id处理方法及装置、存储介质及电子设备

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN108765087A (zh) * 2018-05-31 2018-11-06 康键信息技术(深圳)有限公司 订单异步处理方法、服务器及存储介质
CN109636551A (zh) * 2019-01-31 2019-04-16 上海易点时空网络有限公司 业务订单生成方法及装置
CN109639775A (zh) * 2018-11-27 2019-04-16 湖南蚁为软件有限公司 全局单调递增id生成方法、装置、***及设备
CN110634052A (zh) * 2019-09-20 2019-12-31 中国银行股份有限公司 分布式架构生成订单号的方法及装置

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN108765087A (zh) * 2018-05-31 2018-11-06 康键信息技术(深圳)有限公司 订单异步处理方法、服务器及存储介质
CN109639775A (zh) * 2018-11-27 2019-04-16 湖南蚁为软件有限公司 全局单调递增id生成方法、装置、***及设备
CN109636551A (zh) * 2019-01-31 2019-04-16 上海易点时空网络有限公司 业务订单生成方法及装置
CN110634052A (zh) * 2019-09-20 2019-12-31 中国银行股份有限公司 分布式架构生成订单号的方法及装置

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112073554A (zh) * 2020-09-08 2020-12-11 腾讯科技(深圳)有限公司 全局唯一标识生成方法、设备以及计算机可读存储介质
CN112073554B (zh) * 2020-09-08 2023-04-18 腾讯科技(深圳)有限公司 全局唯一标识生成方法、设备以及计算机可读存储介质
CN112202938A (zh) * 2020-10-12 2021-01-08 广州品唯软件有限公司 Id生成方法、装置及***
CN112199083A (zh) * 2020-10-16 2021-01-08 深圳无域科技技术有限公司 基于表达式的可配置id生成***及方法
CN112667685A (zh) * 2020-12-29 2021-04-16 北京先进数通信息技术股份公司 一种流水号配置方法、装置、设备及存储介质
CN112667685B (zh) * 2020-12-29 2024-04-16 北京先进数通信息技术股份公司 一种流水号配置方法、装置、设备及存储介质
CN114723525A (zh) * 2022-04-08 2022-07-08 湖南快乐阳光互动娱乐传媒有限公司 一种订单id处理方法及装置、存储介质及电子设备

Also Published As

Publication number Publication date
CN111538594B (zh) 2023-04-18

Similar Documents

Publication Publication Date Title
CN111538594B (zh) 基于分布式***的订单id生成方法、装置、设备及介质
CN112948427A (zh) 数据查询方法、装置、设备及存储介质
CN112685117A (zh) ***语言国际化维护方法、装置及计算机可读存储介质
CN114640707A (zh) 一种消息异步处理方法、装置、电子设备及存储介质
CN114356530A (zh) 任务调度方法、装置、电子设备及存储介质
CN112464619B (zh) 大数据处理方法、装置、设备及计算机可读存储介质
CN113297180A (zh) 数据迁移方法、装置、电子设备及存储介质
CN113438304A (zh) 基于数据库集群的数据查询方法、装置、服务器及介质
CN113221154A (zh) 服务密码获取方法、装置、电子设备及存储介质
CN111459510A (zh) 跨网络操作***的安装方法、装置、电子设备及介质
CN113918305B (zh) 节点调度方法、装置、电子设备及可读存储介质
CN115687384A (zh) Uuid标识生成方法、装置、设备及存储介质
CN115174555A (zh) 文件传输方法、装置、电子设备及存储介质
CN114448930A (zh) 短地址生成方法、装置、电子设备及计算机可读存储介质
CN115145870A (zh) 失败任务原因定位方法、装置、电子设备及存储介质
CN114020414A (zh) Android***与底层Linux共生方法、装置、电子设备及存储介质
CN115002011A (zh) 流量双向测试方法、装置、电子设备及存储介质
CN114895942A (zh) 应用换肤方法、装置、设备及存储介质
CN112540839A (zh) 信息变更方法、装置、电子设备及存储介质
CN112631675A (zh) 工作流配置方法、装置、设备及计算机可读存储介质
CN112527443A (zh) 提示框显示方法、装置、电子设备及计算机可读存储介质
CN114003661A (zh) 离线数据录入方法、装置、电子设备及存储介质
CN114201466A (zh) 防缓存击穿方法、装置、设备及可读存储介质
CN113485711A (zh) 基于依赖关系的任务触发方法、装置、电子设备及介质
CN113064797B (zh) 前端监控方法、装置、电子设备及存储介质

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant