CN114510337B - 任务执行方法、系统及计算机可读存储介质 - Google Patents
任务执行方法、系统及计算机可读存储介质 Download PDFInfo
- Publication number
- CN114510337B CN114510337B CN202210392311.1A CN202210392311A CN114510337B CN 114510337 B CN114510337 B CN 114510337B CN 202210392311 A CN202210392311 A CN 202210392311A CN 114510337 B CN114510337 B CN 114510337B
- Authority
- CN
- China
- Prior art keywords
- task
- message
- version number
- stored
- executed
- 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.)
- Active
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/48—Program initiating; Program switching, e.g. by interrupt
- G06F9/4806—Task transfer initiation or dispatching
- G06F9/4843—Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
- G06F9/4881—Scheduling strategies for dispatcher, e.g. round robin, multi-level priority queues
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/54—Interprogram communication
- G06F9/546—Message passing systems or structures, e.g. queues
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2209/00—Indexing scheme relating to G06F9/00
- G06F2209/54—Indexing scheme relating to G06F9/54
- G06F2209/548—Queue
-
- Y—GENERAL 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
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Debugging And Monitoring (AREA)
Abstract
本申请公开了一种任务执行方法、系统及计算机可读存储介质。所述任务执行方法包括:基于预存储的任务描述快照和获取到的任务描述快照,发布至少一条任务调度记录并且更新预存储的任务描述快照,其中,所述至少一条任务调度记录具有相同的版本号;基于任务调度记录生成具有任务调度记录的版本号的至少一条任务消息;根据生成的至少一条任务消息之中的待执行的任务消息的版本号和与预存储的任务描述快照对应的版本号,执行待执行的任务消息。通过本申请,可更准确的实现期望的任务。
Description
技术领域
本申请涉及计算机技术领域,具体涉及一种任务执行方法、系统及计算机可读存储介质。
背景技术
计算机技术的发展和互联网的普及为商品交易提供了便利。基于互联网的计算机系统正在被用于进行与商品交易有关的活动,为卖家和买家提供了便利。这样的计算机系统包括网上购物系统、企业资源计划系统等。
在现有的计算机系统中,可利用任务描述来表示发送邮件、调整商品价格等任务,这样的任务可被称为业务系统任务,并且可基于任务描述生成任务消息。当计算机系统执行任务消息时,可执行业务系统任务。
然而,现有的计算机系统直接基于任务描述生成并执行任务消息。在产生任务更改以改变任务描述的情况下,将生成新任务消息,使得已经存在的旧任务消息与新任务消息同时存在。在执行任务消息时,新任务消息与旧任务消息被同时执行,导致不能准确的实现期望的任务。
发明内容
本申请的实施例提供一种任务执行方法、系统及计算机可读存储介质,可更准确的实现期望的任务。
在第一方面,本申请的实施例提供了一种任务执行方法,包括:基于预存储的任务描述快照和获取到的任务描述快照,发布至少一条任务调度记录并且更新预存储的任务描述快照,其中,所述至少一条任务调度记录具有相同的版本号;基于任务调度记录生成具有任务调度记录的版本号的至少一条任务消息;根据生成的至少一条任务消息之中的待执行的任务消息的版本号和与预存储的任务描述快照对应的版本号,执行待执行的任务消息。
可选的,与预存储的任务描述快照对应的版本号是生效版本号,基于预存储的任务描述快照和获取到的任务描述快照,发布至少一条任务调度记录并且更新预存储的任务描述快照的步骤包括:比较获取到的任务描述快照与预存储的任务描述快照是否相同,当比较的结果是不同时,发布所具有的版本号比生效版本号更新并且所具有的版本号相同的至少一条任务调度记录,将预存储的任务描述快照更新为获取到的任务描述快照,并且将生效版本号更新为发布的至少一条任务调度记录的版本号,和/或,至少一条任务调度记录被存储在任务调度表中,基于至少一条任务调度记录生成具有至少一条任务调度记录的版本号的至少一条任务消息的步骤包括:从任务调度表中读取任务调度记录,生成具有所读取的任务调度记录的版本号的任务消息,并且将生成的任务消息推送到任务消息队列中。
可选的,与预存储的任务描述快照对应的版本号是生效版本号,至少一条任务消息被推送到任务消息队列中,根据生成的至少一条任务消息之中的待执行的任务消息的版本号和与预存储的任务描述快照对应的版本号,执行待执行的任务消息的步骤包括:接收从任务消息队列推送的待执行的任务消息,将待执行的任务消息的版本号与生效版本号进行比较,当生效版本号非空且等于待执行的任务消息的版本号时,执行待执行的任务消息。
可选的,本申请的任务执行方法还包括:当待执行的任务消息被执行时,生成执行结果消息,并且将生成的执行结果消息推送到执行结果消息队列中;接收从执行结果消息队列推送的执行结果消息,当接收到的执行结果消息中存储的执行结果类型为成功或忽略时,生成结果日志,并且当接收到的执行结果消息中存储的执行结果类型为重试时,将与执行结果类型为重试的执行结果消息对应的任务消息推送到任务消息队列中,和/或,当接收到删除指令时,删除预存储的任务描述快照,并且将与预存储的任务描述快照对应的版本号置为空。
可选的,至少一条任务调度记录被存储在任务调度表中,任务调度表以及与预存储的任务描述快照对应的版本号被存储在云存储器中,任务执行方法的至少一个步骤通过无服务器的云函数来执行,存储在任务消息队列中的任务消息和/或存储在执行结果消息队列中且与被执行的任务消息对应的执行结果消息通过无服务器的事件总线来推送。
可选的,待执行的任务消息指示从任务开始时间点至任务结束时间点期间内执行特定操作,特定操作以预定的周期执行,执行待执行的任务消息的步骤还包括:当满足如下公式时,执行特定操作:(当前值-开始值)mod周期内时间数≤(当前值-结束值)mod周期内时间数,其中,mod表示通过将当前值-开始值所获得的结果或者当前值-结束值所获得的结果除以周期内时间数而获得的余数,周期内时间数是一个周期内的时间单位的数量,时间单位包括小时、分钟和秒,当前值是从当前时间点所属的周期的开始时间点至当前时间点所经过的时间单位的数量,开始值是从当前时间点所属的周期的开始时间点至任务开始时间点所经过的时间单位的数量,结束值是从当前时间点所属的周期的开始时间点至任务结束时间点所经过的时间单位的数量。
在第二方面,本申请的实施例提供了一种任务执行系统,包括:快照与记录处理器,被配置为基于预存储的任务描述快照和获取到的任务描述快照,发布至少一条任务调度记录并且更新预存储的任务描述快照,其中,所述至少一条任务调度记录具有相同的版本号;分发器,被配置为基于任务调度记录生成具有任务调度记录的版本号的至少一条任务消息;执行器,被配置为根据生成的至少一条任务消息之中的待执行的任务消息的版本号和与预存储的任务描述快照对应的版本号,执行待执行的任务消息。
可选的,与预存储的任务描述快照对应的版本号是生效版本号,快照与记录处理器包括:比较单元,被配置为比较获取到的任务描述快照与预存储的任务描述快照是否相同;发布单元,被配置为当比较的结果是不同时,发布所具有的版本号比生效版本号更新并且所具有的版本号相同的至少一条任务调度记录;更新单元,被配置为当比较的结果是不同时,将预存储的任务描述快照更新为获取到的任务描述快照,并且将生效版本号更新为发布的至少一条任务调度记录的版本号,和/或,至少一条任务调度记录被存储在任务调度表中,分发器包括:任务消息生成单元,被配置为从任务调度表中读取任务调度记录,生成具有所读取的任务调度记录的版本号的任务消息;任务消息推送单元,被配置为将生成的任务消息推送到任务消息队列中。
可选的,与预存储的任务描述快照对应的版本号是生效版本号,至少一条任务消息被分发器推送到任务消息队列中,执行器包括:版本号比较单元,被配置为接收从任务消息队列推送的待执行的任务消息,将待执行的任务消息的版本号与生效版本号进行比较;任务消息执行单元,被配置为当生效版本号非空且等于待执行的任务消息的版本号时,执行待执行的任务消息;执行结果消息推送单元,被配置为当待执行的任务消息被执行时,生成执行结果消息,并且将生成的执行结果消息推送到执行结果消息队列中。
可选的,本申请的任务执行系统还包括:检查器,被配置为接收从执行结果消息队列推送的执行结果消息,当接收到的执行结果消息中存储的执行结果类型为成功或忽略时,生成结果日志,并且当接收到的执行结果消息中存储的执行结果类型为重试时,将与执行结果类型为重试的执行结果消息对应的任务消息推送到任务消息队列中,和/或,任务删除器,被配置为当接收到删除指令时,删除预存储的任务描述快照,并且将与预存储的任务描述快照对应的版本号置为空。
可选的,至少一条任务调度记录被存储在任务调度表中,任务调度表以及与预存储的任务描述快照对应的版本号被存储在云存储器中,分发器所执行的操作和/或执行器所执行的操作通过无服务器的云函数来执行,存储在任务消息队列中的任务消息通过无服务器的事件总线被推送给执行器,和/或,任务执行系统还包括:检查器,被配置为接收从执行结果消息队列推送的执行结果消息,当接收到的执行结果消息中存储的执行结果类型为成功或忽略时,生成结果日志,并且当接收到的执行结果消息中存储的执行结果类型为重试时,将与执行结果类型为重试的执行结果消息对应的任务消息推送到任务消息队列中;检查器的操作通过无服务器的云函数来执行;存储在执行结果消息队列中且与被执行的任务消息对应的执行结果消息通过无服务器的事件总线被推送给检查器。
可选的,待执行的任务消息指示从任务开始时间点至任务结束时间点期间内执行特定操作,特定操作以预定的周期执行,执行器还被配置为:当满足如下公式时,执行特定操作:(当前值-开始值)mod周期内时间数≤(当前值-结束值)mod周期内时间数,其中,mod表示通过将当前值-开始值所获得的结果或者当前值-结束值所获得的结果除以周期内时间数而获得的余数,周期内时间数是一个周期内的时间单位的数量,时间单位包括小时、分钟和秒,当前值是从当前时间点所属的周期的开始时间点至当前时间点所经过的时间单位的数量,开始值是从当前时间点所属的周期的开始时间点至任务开始时间点所经过的时间单位的数量,结束值是从当前时间点所属的周期的开始时间点至任务结束时间点所经过的时间单位的数量。
在第三方面,本申请的实施例提供了一种计算机可读存储介质,计算机可读存储介质存储有多条指令,指令适于处理器进行加载,以执行本申请的任务执行方法。
本申请的实施例提供的任务执行方法、系统及计算机可读存储介质可实现如下操作:基于预存储的任务描述快照和获取到的任务描述快照,发布至少一条任务调度记录并且更新预存储的任务描述快照,其中,所述至少一条任务调度记录具有相同的版本号;基于任务调度记录生成具有任务调度记录的版本号的至少一条任务消息;根据生成的至少一条任务消息之中的待执行的任务消息的版本号和与预存储的任务描述快照对应的版本号,执行待执行的任务消息。通过本申请的实施例,可基于任务描述快照发布任务调度记录,并且基于发布的任务调度记录生成任务消息,从而执行生成的任务消息。由于根据版本号来执行任务消息,因此可更加准确的执行期望的任务消息,从而更加准确的实现期望的任务。通过本申请的实施例,可将发布任务调度记录的操作、生成任务消息的操作以及执行任务消息的操作分离。例如,可将发布任务调度记录的操作部署在第一系统中,并且将生成任务消息的操作部署在第二系统中,以及将执行任务消息的操作部署在第三系统中。第二系统和第三系统可以是云操作系统等。第二系统和第三系统可以是相同的系统或不同的系统。由于实现了操作分离,因此可减小各个操作之间的相互影响,从而可保证任务的顺利执行。
附图说明
为了更清楚地说明本申请的实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本申请的实施例提供的任务执行方法的流程示意图。
图2为本申请的实施例提供的任务调度记录发布与任务描述快照更新步骤的流程示意图。
图3为本申请的实施例提供的任务消息生成步骤的流程示意图。
图4为本申请的实施例提供的执行任务消息步骤的流程示意图。
图5为本申请的另一实施例提供的任务执行方法的流程示意图。
图6为本申请的又一实施例提供的任务执行方法的流程示意图。
图7为本申请的实施例提供的任务执行系统的结构示意图。
图8为本申请的实施例提供的快照与记录处理器的结构示意图。
图9为本申请的实施例提供的分发器的结构示意图。
图10为本申请的实施例提供的执行器的结构示意图。
图11为本申请的另一实施例提供的任务执行系统的结构示意图。
图12为本申请的又一实施例提供的任务执行系统的结构示意图。
具体实施方式
下面将结合本申请的实施例中的附图,对本申请的实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例。基于本申请的实施例,本领域技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
本申请中的术语“第一”和“第二”等是用于区别不同对象,而不是用于描述特定顺序。此外,术语“包括”和“具有”以及它们任何变形,意图在于覆盖不排他的包含。例如包含了一系列步骤、操作、组件或模块的过程、方法、系统、产品或设备没有限定于已列出的步骤、操作、组件或模块,而是可选地还包括没有列出的步骤、操作、组件或模块,或可选地还包括对于这些过程、方法、产品或设备固有的其它步骤、操作、组件或模块。
在本文中提及“实施例”意味着,结合实施例描述的特定特征、结构或特性可以包含在本申请的至少一个实施例中。在说明书中的各个位置出现该短语并不一定均是指相同的实施例,也不是与其他实施例互斥的独立的或备选的实施例。本领域技术人员显式地和隐式地理解的是,本文所描述的实施例可以与其他实施例相结合。
本申请实施例提供了一种任务执行方法、系统及计算机可读存储介质,以下将分别进行详细说明。需要说明的是,以下各个实施例的描述先后顺序并不构成对具体实施先后顺序的限定,描述先后顺序包括但不限于步骤描述或操作描述的先后顺序和系统组成部分描述的先后顺序。
参照图1所示任务执行方法的流程示意图,该任务执行方法可以包括:任务调度记录发布与任务描述快照更新步骤、任务消息生成步骤以及任务消息执行步骤。
在任务调度记录发布与任务描述快照更新步骤,可基于预存储的任务描述快照和获取到的任务描述快照,发布至少一条任务调度记录并且更新预存储的任务描述快照,其中,发布的任务调度记录具有相同的版本号。
随着电商平台多样化、交易规模巨量化、综合服务大、卖家批量化涌现、产业链分工更细化及完善,用户需求也越来越多。用户需求可通过网上购物系统、企业资源计划系统等计算机系统来实现。这样的计算机系统也可称为业务系统,这样的用户需求可通过执行相应的任务来实现,这里的任务可以是业务系统任务。在计算机系统中,用户需求可通过任务描述来记录,任务描述可用于表示发送邮件、调整商品价格等任务。可基于用户输入生成任务描述,并且基于任务描述生成任务描述快照。任务描述快照可以记录任务描述的内容。可预先存储任务描述快照,并且可预先存储两个版本的任务描述快照,便于进行回滚等操作。
作为示例,业务系统任务可以是定时任务。定时任务包括:在时间点执行的任务、在时间段内执行的任务、周期性执行的任务。
作为示例,可在与用户需求对应的任务描述的生成之后发布任务调度记录,甚至可在任务描述的生成之后立刻发布任务调度记录。在这种情况下,可及时将任务描述记录下来,从而及时将用户需求记录下来。任务调度记录的发布可在业务系统中实现,甚至可由业务系统中的组件来实现,例如,由下文描述的快照与记录处理器来实现。另外,生成任务消息的操作和/或执行任务消息的操作,可通过时间触发而被激活,或者通过事件触发而被激活。生成任务消息的操作可在第二系统中被执行或者被相应的组件执行,例如,由下文描述的分发器来执行。执行任务消息的操作可在第三系统中被执行或者被相应的组件执行,例如,由下文描述的执行器来执行。第二系统和第三系统可以是云操作系统等。第二系统和第三系统可以是相同的系统或不同的系统。
在本申请的实施例中,与预存储的任务描述快照对应的版本号是生效版本号。参照图2所示任务调度记录发布与任务描述快照更新步骤的流程示意图,基于预存储的任务描述快照和获取到的任务描述快照,发布至少一条任务调度记录并且更新预存储的任务描述快照的步骤可包括:比较获取到的任务描述快照与预存储的任务描述快照是否相同,当比较的结果是不同时,发布所具有的版本号比生效版本号更新并且所具有的版本号相同的至少一条任务调度记录,将预存储的任务描述快照更新为获取到的任务描述快照,并且将生效版本号更新为发布的至少一条任务调度记录的版本号。
作为示例,当用户产生新的需求或者用户更改旧的需求时,可生成新的任务描述。在这种情况下,可基于新的任务描述生成新的任务描述快照,以记录任务描述的内容。在将获取到的任务描述快照与预存储的任务描述快照进行比较的过程中,可比较任务描述快照的内容,可将具有不同内容的任务描述快照视为不同的任务描述快照。
例如,第一任务描述可指示在每天的18:00至20:00将商品A的价格从5元修改为6元。第二任务描述可指示在每天的18:30至20:30将商品A的价格从5元修改为6元。在这种情况下,与第一任务描述对应的第一任务描述快照不同于与第二任务描述对应的第二任务描述快照。
作为示例,版本号可以用阿拉伯数字来表示,可认为版本号越大,则版本越新。版本号越新可表示产生时间越晚。
通过上述操作,可通过任务描述快照以及版本号体现任务描述的更改,也可体现用户需求的更改,由此可准确反映用户需求。
返回参照图1,在任务消息生成步骤,基于至少一条任务调度记录生成具有至少一条任务调度记录的版本号的至少一条任务消息。作为示例,可将任务调度记录中存储的版本号作为所生成的任务消息的版本号。
在本申请的实施例中,至少一条任务调度记录被存储在任务调度表中。参照图3所示任务消息生成步骤,基于至少一条任务调度记录生成具有至少一条任务调度记录的版本号的至少一条任务消息的步骤包括:从任务调度表中读取任务调度记录,生成具有所读取的任务调度记录的版本号的任务消息,并且将生成的任务消息推送到任务消息队列中。
作为示例,任务调度表可存储一条或更多条任务调度记录,任务调度表可被存储在存储器中;存储器可以是本地存储器或远程存储器,如云存储器等。可定时从任务调度表中读取任务调度记录,也可当特定事件发生时从任务调度表中读取任务调度记录。生成的任务消息可以是任务请求,当任务请求被处理器执行时,可执行特定的业务系统任务,例如发送邮件、调整商品价格等业务系统任务。
作为示例,任务调度记录可包括多个字段,例如状态字段和版本号字段,状态字段可存储与业务系统任务对应的参数,当业务系统任务是邮件发送时,参数可包括:邮件发送时间点、收件地址和邮件内容;当业务系统任务是分时调价时,参数可包括:商品标识、调整时段和期望价格。
返回参照图1,在任务消息执行步骤,根据生成的至少一条任务消息之中的待执行的任务消息的版本号和与预存储的任务描述快照对应的版本号,执行待执行的任务消息。也就是说,可根据待执行的任务消息的版本号和与预存储的任务描述快照对应的版本号,判断任务消息是否需要被执行。
在本申请的实施例中,与预存储的任务描述快照对应的版本号可以是生效版本号,至少一条任务消息被推送到任务消息队列中。参照图4所示执行任务消息步骤的流程示意图,根据生成的至少一条任务消息之中的待执行的任务消息的版本号和与预存储的任务描述快照对应的版本号,执行待执行的任务消息的步骤包括:接收从任务消息队列推送的待执行的任务消息,将待执行的任务消息的版本号与生效版本号进行比较,当生效版本号非空且等于待执行的任务消息的版本号时,执行待执行的任务消息。
通过版本号比较,可判断任务消息的版本是否与生效版本号相匹配,可在匹配时允许任务消息的执行,并且在不匹配时不允许任务消息的执行。
参照图5所示本申请的另一实施例提供的任务执行方法的流程示意图,本申请的任务执行方法可包括:基于预存储的任务描述快照和获取到的任务描述快照,发布至少一条任务调度记录并且更新预存储的任务描述快照,其中,发布的任务调度记录具有相同的版本号;基于至少一条任务调度记录生成具有至少一条任务调度记录的版本号的至少一条任务消息;根据生成的至少一条任务消息之中的待执行的任务消息的版本号和与预存储的任务描述快照对应的版本号,执行待执行的任务消息;当待执行的任务消息被执行时,生成执行结果消息,并且将生成的执行结果消息推送到执行结果消息队列中;接收从执行结果消息队列推送的执行结果消息,当接收到的执行结果消息中存储的执行结果类型为成功或忽略时,生成结果日志,并且当接收到的执行结果消息中存储的执行结果类型为重试时,将与执行结果类型为重试的执行结果消息对应的任务消息推送到任务消息队列中。
通过执行结果消息的执行结果类型,可对任务消息的执行结果进行检查。根据执行结果类型可进行结果日志的生成和任务消息的重试。结果日志可被推送给业务系统,从而业务系统可获知执行结果。通过上述方案,还可对任务消息进行重试。也就是说,进行重试的任务消息可被重新执行,从而保证任务消息执行的成功率。需要被重试的任务消息虽然未被成功执行,但是未成功的原因可能是应用程序并发异常所导致,通过重试,这样的任务消息可能会被执行成功,因此通过上述检查,可保证任务消息被顺利执行,从而进一步保证任务的顺利执行。
参照图6所示任务执行方法的流程示意图,本申请的任务执行方法可包括:基于预存储的任务描述快照和获取到的任务描述快照,发布至少一条任务调度记录并且更新预存储的任务描述快照,其中,发布的任务调度记录具有相同的版本号;基于至少一条任务调度记录生成具有至少一条任务调度记录的版本号的至少一条任务消息;根据生成的至少一条任务消息之中的待执行的任务消息的版本号和与预存储的任务描述快照对应的版本号,执行待执行的任务消息;当接收到删除指令时,删除预存储的任务描述快照,并且将与预存储的任务描述快照对应的版本号置为空。
通过上述方案,还可实现任务删除操作。通过任务描述快照的删除和将版本号置为空的操作,可保证在进行版本号比较以确定是否执行任务消息时,准确识别出不需要被执行的任务消息,从而保证任务删除操作的顺利实现。
在本申请的实施例中,至少一条任务调度记录被存储在任务调度表中,任务调度表以及与预存储的任务描述快照对应的版本号被存储在云存储器中,任务执行方法的至少一个步骤通过无服务器(Serverless)的云函数来执行,存储在任务消息队列中的任务消息和/或存储在执行结果消息队列中且与被执行的任务消息对应的执行结果消息通过无服务器的事件总线(EventBridge)来推送。
在业务系统上线、断电等原因导致业务系统停机或重启时,由于云存储器与无服务器独立于业务系统,即使业务系统出现停机或重启等状况,也可通过无服务器和云存储器的配合来实现本申请的相应方案,因此可保证与任务描述快照对应的用户需求的实现。
在本申请的实施例中,待执行的任务消息指示从任务开始时间点至任务结束时间点期间内执行特定操作,特定操作以预定的周期执行,执行待执行的任务消息的步骤还包括:当满足如下公式时,执行特定操作:(当前值-开始值)mod周期内时间数≤(当前值-结束值)mod周期内时间数,其中,mod表示通过将当前值-开始值所获得的结果或者当前值-结束值所获得的结果除以周期内时间数而获得的余数,周期内时间数是一个周期内的时间单位的数量,时间单位包括小时、分钟和秒,当前值是从当前时间点所属的周期的开始时间点至当前时间点所经过的时间单位的数量,开始值是从当前时间点所属的周期的开始时间点至任务开始时间点所经过的时间单位的数量,结束值是从当前时间点所属的周期的开始时间点至任务结束时间点所经过的时间单位的数量。
通过以上方案,可保证即使从任务开始时间点至任务结束时间点的这段时间跨越了0:00这个时刻,也可保证特定操作的按时执行。
如上所述,通过本申请的实施例提供的任务执行方法,可基于任务描述快照发布任务调度记录,基于任务调度记录生成任务消息,并且基于版本号来执行任务消息;为任务消息设置与任务调度记录匹配的版本号。在这种情况下,可实现有效的分离,即实现任务调度记录发布、任务消息生成以及任务消息执行的分离。可通过版本号保证旧版本任务消息的失效和新版本任务消息的生效。由于任务消息的版本号与任务调度记录的版本号匹配并且还与对应的任务描述快照匹配,并且对具有需要的版本号的任务消息进行执行,而被执行的带有版本号的任务消息对应于具有相应版本号的任务描述快照,也对应于具有相应版本号的任务描述快照所对应的用户需求,从而可准确实现用户需求。本申请的技术方案,也适用于当用户需求包括周期性执行业务系统任务的场景,例如,周期性发送邮件、调整商品价格等场景。
为了实施以上任务执行方法,相应的,本申请的实施例还提供一种任务执行系统。参照图7所示的任务执行系统的结构示意图,本申请的任务执行系统可包括快照与记录处理器100、分发器200以及执行器300。
快照与记录处理器100可被配置为基于预存储的任务描述快照和获取到的任务描述快照,发布至少一条任务调度记录并且更新预存储的任务描述快照,其中,发布的任务调度记录具有相同的版本号;分发器200可被配置为基于至少一条任务调度记录生成具有至少一条任务调度记录的版本号的至少一条任务消息;执行器300可被配置为根据生成的至少一条任务消息之中的待执行的任务消息的版本号和与预存储的任务描述快照对应的版本号,执行待执行的任务消息。
在示例性实施例中,可基于预存储的任务描述快照和获取到的任务描述快照,发布至少一条任务调度记录并且更新预存储的任务描述快照,其中,发布的任务调度记录具有相同的版本号。
作为示例,可在与用户需求对应的任务描述的生成之后发布任务调度记录,甚至可在任务描述的生成之后立刻发布任务调度记录。在这种情况下,可及时将任务描述记录下来,从而及时将用户需求记录下来。快照与记录处理器100可在业务系统中实现,可通过时间或事件触发而被激活。分发器200和/或执行器300,可通过时间触发而被激活,或者通过事件触发而被激活,例如通过无服务器的事件总线来触发。分发器200可在第二系统中实现。执行器300可在第三系统中实现。第二系统和第三系统可以是云操作系统等。第二系统和第三系统可以是相同的系统或不同的系统。
在本申请的实施例中,与预存储的任务描述快照对应的版本号是生效版本号。参照图8所示快照与记录处理器的结构示意图,快照与记录处理器100包括:比较单元101,被配置为比较获取到的任务描述快照与预存储的任务描述快照是否相同;发布单元102,被配置为当比较的结果是不同时,发布所具有的版本号比生效版本号更新并且所具有的版本号相同的至少一条任务调度记录;更新单元103,被配置为当比较的结果是不同时,将预存储的任务描述快照更新为获取到的任务描述快照,并且将生效版本号更新为发布的至少一条任务调度记录的版本号。
作为示例,当用户产生新的需求或者用户更改旧的需求时,可生成新的任务描述。在这种情况下,可基于新的任务描述生成新的任务描述快照,以记录任务描述的内容。在将获取到的任务描述快照与预存储的任务描述快照进行比较的过程中,可比较任务描述快照的内容,可将具有不同内容的任务描述快照视为不同的任务描述快照。
例如,第一任务描述可指示在每天的18:00至20:00将商品A的价格从5元修改为6元。第二任务描述可指示在每天的18:30至20:30将商品A的价格从5元修改为6元。在这种情况下,与第一任务描述对应的第一任务描述快照不同于与第二任务描述对应的第二任务描述快照。
作为示例,版本号可以用阿拉伯数字来表示,可认为版本号越大,则版本越新。版本号越新可表示产生时间越晚。
通过上述操作,可通过任务描述快照以及版本号体现任务描述的更改,也可体现用户需求的更改,由此可准确反映用户需求。
在本申请的实施例中,至少一条任务调度记录被存储在任务调度表中。参照图9所示分发器的结构示意图,分发器200包括:任务消息生成单元201,被配置为从任务调度表中读取任务调度记录,生成具有所读取的任务调度记录的版本号的任务消息;任务消息推送单元202,被配置为将生成的任务消息推送到任务消息队列中。
作为示例,任务调度表可存储一条或更多条任务调度记录,任务调度表可被存储在存储器中;存储器可以是本地存储器或远程存储器,如云存储器等。可定时从任务调度表中读取任务调度记录,也可当特定事件发生时从任务调度表中读取任务调度记录。生成的任务消息可以是任务请求,当任务请求被处理器执行时,可执行特定的业务系统任务,例如发送邮件、调整商品价格等业务系统任务。
作为示例,任务调度记录可包括多个字段,例如状态字段和版本号字段,状态字段可存储与业务系统任务对应的参数,当业务系统任务是邮件发送时,参数可包括:邮件发送时间点、收件地址和邮件内容;当业务系统任务是分时调价时,参数可包括:商品标识、调整时段和期望价格。
在本申请的实施例中,与预存储的任务描述快照对应的版本号是生效版本号,至少一条任务消息被分发器推送到任务消息队列中。参照图10所示执行器300的结构示意图,执行器300包括:版本号比较单元301,被配置为接收从任务消息队列推送的待执行的任务消息,将待执行的任务消息的版本号与生效版本号进行比较;任务消息执行单元302,被配置为当生效版本号非空且等于待执行的任务消息的版本号时,执行待执行的任务消息;执行结果消息推送单元303,被配置为当待执行的任务消息被执行时,生成执行结果消息,并且将生成的执行结果消息推送到执行结果消息队列中。
通过版本号比较,可判断任务消息的版本是否与生效版本号相匹配,可在匹配时允许任务消息的执行,并且在不匹配时不允许任务消息的执行。
参照图11所示本申请的实施例提供的任务执行系统的结构示意图,本申请的任务执行系统可包括:快照与记录处理器100,被配置为基于预存储的任务描述快照和获取到的任务描述快照,发布至少一条任务调度记录并且更新预存储的任务描述快照,其中,发布的任务调度记录具有相同的版本号;分发器200,被配置为基于至少一条任务调度记录生成具有至少一条任务调度记录的版本号的至少一条任务消息;执行器300,被配置为根据生成的至少一条任务消息之中的待执行的任务消息的版本号和与预存储的任务描述快照对应的版本号,执行待执行的任务消息;检查器400,被配置为接收从执行结果消息队列推送的执行结果消息,当接收到的执行结果消息中存储的执行结果类型为成功或忽略时,生成结果日志,并且当接收到的执行结果消息中存储的执行结果类型为重试时,将与执行结果类型为重试的执行结果消息对应的任务消息推送到任务消息队列中。
通过执行结果消息的执行结果类型,可对任务消息的执行结果进行检查。根据执行结果类型可进行结果日志的生成和任务消息的重试。结果日志可被推送给业务系统,从而业务系统可获知执行结果。通过上述方案,还可对任务消息进行重试。也就是说,进行重试的任务消息可被重新执行,从而保证任务消息执行的成功率。需要被重试的任务消息虽然未被成功执行,但是未成功的原因可能是应用程序并发异常所导致,通过重试,这样的任务消息可能会被执行成功,因此通过上述检查,可保证任务消息被顺利执行,从而进一步保证任务的顺利执行。
参照图12所示本申请的实施例提供的任务执行系统的结构示意图,本申请的任务执行系统可包括:快照与记录处理器100,被配置为基于预存储的任务描述快照和获取到的任务描述快照,发布至少一条任务调度记录并且更新预存储的任务描述快照,其中,发布的任务调度记录具有相同的版本号;分发器200,被配置为基于至少一条任务调度记录生成具有至少一条任务调度记录的版本号的至少一条任务消息;执行器300,被配置为根据生成的至少一条任务消息之中的待执行的任务消息的版本号和与预存储的任务描述快照对应的版本号,执行待执行的任务消息;任务删除器500,被配置为当接收到删除指令时,删除预存储的任务描述快照,并且将与预存储的任务描述快照对应的版本号置为空。
通过上述方案,还可实现任务删除操作。通过任务描述快照的删除和将版本号置为空的操作,可保证在进行版本号比较以确定是否执行任务消息时,准确识别出不需要被执行的任务消息,从而保证任务删除操作的顺利实现。
在本申请的实施例中,至少一条任务调度记录被存储在任务调度表中,任务调度表以及与预存储的任务描述快照对应的版本号被存储在云存储器中,分发器所执行的操作和/或执行器所执行的操作通过无服务器的云函数来执行,存储在任务消息队列中的任务消息通过无服务器的事件总线被推送给执行器。
在本申请的实施例中,任务执行系统还包括:检查器,被配置为接收从执行结果消息队列推送的执行结果消息,当接收到的执行结果消息中存储的执行结果类型为成功或忽略时,生成结果日志,并且当接收到的执行结果消息中存储的执行结果类型为重试时,将与执行结果类型为重试的执行结果消息对应的任务消息推送到任务消息队列中;检查器的操作通过无服务器的云函数来执行;存储在执行结果消息队列中且与被执行的任务消息对应的执行结果消息通过无服务器的事件总线被推送给检查器。
在业务系统上线、断电等原因导致业务系统停机或重启时,由于云存储器与无服务器独立于业务系统,即使业务系统出现停机或重启等状况,也可通过无服务器和云存储器的配合来实现本申请的相应方案,因此可保证与任务描述快照对应的用户需求的实现。
在本申请的实施例中,待执行的任务消息指示从任务开始时间点至任务结束时间点期间内执行特定操作,特定操作以预定的周期执行,执行器还被配置为:当满足如下公式时,执行特定操作:(当前值-开始值)mod周期内时间数≤(当前值-结束值)mod周期内时间数,其中,mod表示通过将当前值-开始值所获得的结果或者当前值-结束值所获得的结果除以周期内时间数而获得的余数,周期内时间数是一个周期内的时间单位的数量,时间单位包括小时、分钟和秒,当前值是从当前时间点所属的周期的开始时间点至当前时间点所经过的时间单位的数量,开始值是从当前时间点所属的周期的开始时间点至任务开始时间点所经过的时间单位的数量,结束值是从当前时间点所属的周期的开始时间点至任务结束时间点所经过的时间单位的数量。
通过以上方案,可保证即使从任务开始时间点至任务结束时间点的这段时间跨越了0:00这个时刻,也可保证特定操作的按时执行。
上述所有的技术方案,可以采用任意结合形成本申请的可选实施例,在此不再一一赘述。
根据本申请的示例性实施例,提供了一种计算机可读存储介质,计算机可读存储介质存储有多条指令,指令适于处理器进行加载,以执行本申请的示例性实施例提供的任务执行方法。
也就是说,本领域普通技术人员可以理解,上述实施例的各种方法中的全部或部分步骤可以通过指令来完成,或通过指令控制相关的硬件来完成,该指令可以存储于一计算机可读存储介质中,并由处理器进行加载和执行。
通过示例性实施例中的指令,可以执行如下步骤或操作:基于预存储的任务描述快照和获取到的任务描述快照,发布至少一条任务调度记录并且更新预存储的任务描述快照,其中,发布的任务调度记录具有相同的版本号;基于任务调度记录生成具有任务调度记录的版本号的至少一条任务消息;根据生成的至少一条任务消息之中的待执行的任务消息的版本号和与预存储的任务描述快照对应的版本号,执行待执行的任务消息。
以上任务执行系统的各个组成部分的具体实施可参见前面的实施例,在此不再赘述。
另外,在本申请的示例性实施例中,在已经确定需要在预定时间点向任务消息队列中推送任务消息的情况下,可在比预定时间点更早的时间点推送任务消息,从而可避免任务消息队列中已经存在的任务消息的执行影响需要被推送的任务消息的按时执行。在本申请的示例性实施例中,可针对快照与记录处理器100、分发器200、执行器300、检查器400和/或任务删除器500所执行的操作以及相应的方法步骤进行异步化处理。
本申请的示例性实施例的计算机可读存储介质可以包括:只读存储器(ROM,ReadOnly Memory)、随机存取记忆体(RAM,Random Access Memory)、磁盘或光盘等。
由于该计算机可读存储介质中所存储的指令,可以执行本申请实施例所提供的任一任务执行方法中的步骤,因此,可以实现本申请实施例所提供的任一任务执行方法所能实现的有益效果,详见前面的实施例,在此不再赘述。
本申请应用了具体个例对本申请的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本申请的方法及其核心思想;同时,对于本领域的技术人员,依据本申请的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本申请的限制。
Claims (9)
1.一种任务执行方法,其特征在于,包括:
基于预存储的任务描述快照和获取到的任务描述快照,发布具有相同版本号的至少一条任务调度记录并且更新所述预存储的任务描述快照;
基于所述至少一条任务调度记录生成具有所述至少一条任务调度记录的版本号的至少一条任务消息;
根据生成的至少一条任务消息之中的待执行的任务消息的版本号和与所述预存储的任务描述快照对应的版本号判断是否相匹配,
执行所述待执行的任务消息,所述待执行的任务消息指示从任务开始时间点至任务结束时间点期间内执行特定操作,所述特定操作以预定的周期执行,所述执行所述待执行的任务消息的步骤还包括:
当满足如下公式时,执行所述特定操作:
(当前值-开始值)mod周期内时间数≤(当前值-结束值)mod周期内时间数,
其中,mod表示取余运算,周期内时间数是一个周期内的时间单位的数量,所述时间单位包括小时、分钟和秒,当前值是从当前时间点所属的周期的开始时间点至当前时间点所经过的时间单位的数量,开始值是从当前时间点所属的周期的开始时间点至所述任务开始时间点所经过的时间单位的数量,结束值是从当前时间点所属的周期的开始时间点至所述任务结束时间点所经过的时间单位的数量;
当所述待执行的任务消息被执行时,生成执行结果消息,并且将生成的执行结果消息推送到执行结果消息队列中;接收从所述执行结果消息队列推送的执行结果消息,当接收到的执行结果消息中存储的执行结果类型为成功或忽略时,生成结果日志,并且当接收到的执行结果消息中存储的执行结果类型为重试时,将与执行结果类型为重试的执行结果消息对应的任务消息推送到任务消息队列中,和/或,
当接收到删除指令时,删除所述预存储的任务描述快照,并且将与所述预存储的任务描述快照对应的版本号置为空。
2.如权利要求1所述的任务执行方法,其特征在于,与所述预存储的任务描述快照对应的版本号是生效版本号,所述基于预存储的任务描述快照和获取到的任务描述快照,发布具有相同版本号的至少一条任务调度记录并且更新所述预存储的任务描述快照的步骤包括:比较所述获取到的任务描述快照与所述预存储的任务描述快照是否相同,当所述比较的结果是不同时,发布所具有的版本号比所述生效版本号更新并且所具有的版本号相同的至少一条任务调度记录,将所述预存储的任务描述快照更新为所述获取到的任务描述快照,并且将所述生效版本号更新为发布的至少一条任务调度记录的版本号,和/或,
所述至少一条任务调度记录被存储在任务调度表中,所述基于所述至少一条任务调度记录生成具有所述至少一条任务调度记录的版本号的至少一条任务消息的步骤包括:从所述任务调度表中读取任务调度记录,生成具有所读取的任务调度记录的版本号的任务消息,并且将生成的任务消息推送到任务消息队列中。
3.如权利要求1所述的任务执行方法,其特征在于,与所述预存储的任务描述快照对应的版本号是生效版本号,所述至少一条任务消息被推送到任务消息队列中,所述根据生成的至少一条任务消息之中的待执行的任务消息的版本号和与所述预存储的任务描述快照对应的版本号,执行所述待执行的任务消息的步骤包括:
接收从所述任务消息队列推送的待执行的任务消息,将所述待执行的任务消息的版本号与所述生效版本号进行比较,当所述生效版本号非空且等于所述待执行的任务消息的版本号时,执行所述待执行的任务消息。
4.如权利要求1所述的任务执行方法,其特征在于,所述至少一条任务调度记录被存储在任务调度表中,所述任务调度表以及与所述预存储的任务描述快照对应的版本号被存储在云存储器中,所述任务执行方法的至少一个步骤通过无服务器的云函数来执行,存储在任务消息队列中的任务消息和/或存储在执行结果消息队列中且与被执行的任务消息对应的执行结果消息通过无服务器的事件总线来推送。
5.一种任务执行系统,其特征在于,包括:
快照与记录处理器,被配置为基于预存储的任务描述快照和获取到的任务描述快照,发布具有相同版本号的至少一条任务调度记录并且更新所述预存储的任务描述快照;
分发器,被配置为基于所述至少一条任务调度记录生成具有所述至少一条任务调度记录的版本号的至少一条任务消息;
执行器,被配置为根据生成的至少一条任务消息之中的待执行的任务消息的版本号和与所述预存储的任务描述快照对应的版本号判断是否相匹配,执行所述待执行的任务消息,所述待执行的任务消息指示从任务开始时间点至任务结束时间点期间内执行特定操作,所述特定操作以预定的周期执行,所述执行器还被配置为:
当满足如下公式时,执行所述特定操作:
(当前值-开始值)mod周期内时间数≤(当前值-结束值)mod周期内时间数,
其中,mod表示取余运算,周期内时间数是一个周期内的时间单位的数量,所述时间单位包括小时、分钟和秒,当前值是从当前时间点所属的周期的开始时间点至当前时间点所经过的时间单位的数量,开始值是从当前时间点所属的周期的开始时间点至所述任务开始时间点所经过的时间单位的数量,结束值是从当前时间点所属的周期的开始时间点至所述任务结束时间点所经过的时间单位的数量;
检查器,被配置为接收从执行结果消息队列推送的执行结果消息,当接收到的执行结果消息中存储的执行结果类型为成功或忽略时,生成结果日志,并且当接收到的执行结果消息中存储的执行结果类型为重试时,将与执行结果类型为重试的执行结果消息对应的任务消息推送到任务消息队列中,和/或,
任务删除器,被配置为当接收到删除指令时,删除所述预存储的任务描述快照,并且将与所述预存储的任务描述快照对应的版本号置为空。
6.如权利要求5所述的任务执行系统,其特征在于,与所述预存储的任务描述快照对应的版本号是生效版本号,所述快照与记录处理器包括:比较单元,被配置为比较所述获取到的任务描述快照与所述预存储的任务描述快照是否相同;发布单元,被配置为当所述比较的结果是不同时,发布所具有的版本号比所述生效版本号更新并且所具有的版本号相同的至少一条任务调度记录;更新单元,被配置为当所述比较的结果是不同时,将所述预存储的任务描述快照更新为所述获取到的任务描述快照,并且将所述生效版本号更新为发布的至少一条任务调度记录的版本号,和/或,
所述至少一条任务调度记录被存储在任务调度表中,所述分发器包括:任务消息生成单元,被配置为从所述任务调度表中读取任务调度记录,生成具有所读取的任务调度记录的版本号的任务消息;任务消息推送单元,被配置为将生成的任务消息推送到任务消息队列中。
7.如权利要求5所述的任务执行系统,其特征在于,与所述预存储的任务描述快照对应的版本号是生效版本号,所述至少一条任务消息被所述分发器推送到任务消息队列中,所述执行器包括:
版本号比较单元,被配置为接收从所述任务消息队列推送的待执行的任务消息,将所述待执行的任务消息的版本号与所述生效版本号进行比较;
任务消息执行单元,被配置为当所述生效版本号非空且等于所述待执行的任务消息的版本号时,执行所述待执行的任务消息;
执行结果消息推送单元,被配置为当所述待执行的任务消息被执行时,生成执行结果消息,并且将生成的执行结果消息推送到执行结果消息队列中。
8.如权利要求5所述的任务执行系统,其特征在于,所述至少一条任务调度记录被存储在任务调度表中,所述任务调度表以及与所述预存储的任务描述快照对应的版本号被存储在云存储器中,所述分发器所执行的操作和/或所述执行器所执行的操作通过无服务器的云函数来执行,存储在任务消息队列中的任务消息通过无服务器的事件总线被推送给所述执行器,和/或,
所述任务执行系统还包括:检查器,被配置为接收从执行结果消息队列推送的执行结果消息,当接收到的执行结果消息中存储的执行结果类型为成功或忽略时,生成结果日志,并且当接收到的执行结果消息中存储的执行结果类型为重试时,将与执行结果类型为重试的执行结果消息对应的任务消息推送到任务消息队列中;所述检查器的操作通过无服务器的云函数来执行;存储在执行结果消息队列中且与被执行的任务消息对应的执行结果消息通过无服务器的事件总线被推送给所述检查器。
9.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质存储有指令,所述指令适于处理器进行加载,以执行权利要求1至4中任一项所述的任务执行方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210392311.1A CN114510337B (zh) | 2022-04-15 | 2022-04-15 | 任务执行方法、系统及计算机可读存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210392311.1A CN114510337B (zh) | 2022-04-15 | 2022-04-15 | 任务执行方法、系统及计算机可读存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN114510337A CN114510337A (zh) | 2022-05-17 |
CN114510337B true CN114510337B (zh) | 2023-03-21 |
Family
ID=81554865
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210392311.1A Active CN114510337B (zh) | 2022-04-15 | 2022-04-15 | 任务执行方法、系统及计算机可读存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114510337B (zh) |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108563502A (zh) * | 2017-12-14 | 2018-09-21 | 中国银联股份有限公司 | 一种任务调度方法和装置 |
WO2021104178A1 (zh) * | 2019-11-27 | 2021-06-03 | 深圳市道通科技股份有限公司 | 一种动态消息推送方法、系统和汽车诊断服务器 |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103049334B (zh) * | 2012-12-14 | 2015-09-30 | 华为技术有限公司 | 一种任务处理的方法和虚拟机 |
CN105511954B (zh) * | 2014-09-23 | 2020-07-07 | 华为技术有限公司 | 一种报文处理方法及装置 |
US9778961B2 (en) * | 2015-09-14 | 2017-10-03 | Qualcomm Incorporated | Efficient scheduling of multi-versioned tasks |
CN106101021B (zh) * | 2016-05-31 | 2019-06-14 | 河南理工大学 | 一种以太网系统功能块的实时执行调度方法 |
-
2022
- 2022-04-15 CN CN202210392311.1A patent/CN114510337B/zh active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108563502A (zh) * | 2017-12-14 | 2018-09-21 | 中国银联股份有限公司 | 一种任务调度方法和装置 |
WO2021104178A1 (zh) * | 2019-11-27 | 2021-06-03 | 深圳市道通科技股份有限公司 | 一种动态消息推送方法、系统和汽车诊断服务器 |
Also Published As
Publication number | Publication date |
---|---|
CN114510337A (zh) | 2022-05-17 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CA3176449A1 (en) | Sales locking method and system based on a caching | |
CN1783132B (zh) | 通过工作流事务的批处理来同步运行库和应用状态 | |
CN104699712B (zh) | 对数据库中的库存记录信息进行更新的方法及装置 | |
CN109191233B (zh) | 一种秒杀下单请求处理方法、装置和存储介质 | |
CN110941502A (zh) | 消息处理方法、装置、存储介质及设备 | |
CN109840146A (zh) | 业务处理方法、装置、终端及存储介质 | |
US9189303B2 (en) | Shadow queues for recovery of messages | |
CN103092903A (zh) | 数据库日志并行化 | |
CN113094362A (zh) | 一种异步消息可靠投递和处理的方法和装置 | |
CN106991606B (zh) | 交易数据处理方法及装置 | |
CN110740184A (zh) | 基于微服务架构的交易策略测试系统 | |
CN109426550A (zh) | 资源的调度方法及设备 | |
CN111144804A (zh) | 一种订单处理方法、装置及系统 | |
CN114510337B (zh) | 任务执行方法、系统及计算机可读存储介质 | |
CN114119129A (zh) | 一种高并发秒杀系统 | |
US20200142985A1 (en) | Asynchronously publishing events to a message bus in an event-driven computing system | |
CN114546629B (zh) | 任务执行系统、方法、服务器及计算机可读存储介质 | |
CN110765144B (zh) | 分布式异构数据库数据处理方法及装置 | |
CN110532108B (zh) | 简历投递任务的处理方法、装置、服务器和系统 | |
CN115271835A (zh) | 一种发票生成方法、装置、电子设备及存储介质 | |
CN111967929A (zh) | 订单巡检方法及装置、电子设备、存储介质 | |
CN112330420A (zh) | 一种订单取消方法和相关装置 | |
CN112131251A (zh) | 竞价交易方法、装置、可读存储介质及电子设备 | |
CN112199213B (zh) | 一种挂单交互数据的数据交互方法及服务器 | |
CN110689429A (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 |