CN108228355A - 任务处理方法及装置、任务调度方法及装置 - Google Patents
任务处理方法及装置、任务调度方法及装置 Download PDFInfo
- Publication number
- CN108228355A CN108228355A CN201810002315.8A CN201810002315A CN108228355A CN 108228355 A CN108228355 A CN 108228355A CN 201810002315 A CN201810002315 A CN 201810002315A CN 108228355 A CN108228355 A CN 108228355A
- Authority
- CN
- China
- Prior art keywords
- task
- server
- dispatch server
- multiple tasks
- client terminal
- 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.)
- Pending
Links
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/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5027—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
-
- 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
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 And Data Communications (AREA)
Abstract
本发明涉及互联网技术领域,具体涉及一种任务处理方法及装置、任务调度方法及装置,该任务处理方法应用于客户终端,该客户终端与调度服务器连接,该调度服务器与多个任务服务器均连接。其中,客户终端发送多个任务至调度服务器的数据池中,由调度服务器对每个任务分配唯一标识并将多个任务的唯一标识发送至客户终端,此外,该调度服务器还按照预设的分配规则将多个任务发送至多个任务服务器,由任务服务器执行多个任务得到任务执行结果,进而将任务执行结果反馈至调度服务器的数据池中供客户终端根据任务的唯一标识进行查询。
Description
技术领域
本发明涉及互联网技术领域,具体而言,涉及一种任务处理方法及装置、任务调度方法及装置。
背景技术
传统的PHP代码流程都是单进程顺序执行,如在一个过程中需要进行大量计算或者请第三方API接口等任务,都得等上一个流程结束后才能执行下一个请求,非常耗时,并对机器的性能要求很高。因此,提供一种能够并发执行多种任务,以减少耗时,减少服务器压力的方法是十分必要的。
发明内容
本发明的目的在于提供一种任务处理方法及装置,以实现同时执行多种任务,减少任务执行时间,减少服务器的压力。
本发明的另一目的在于提供一种任务调度方法及装置,以实现同时对多种任务进行调度得到任务执行结果,缩短任务执行时间。
为了实现上述目的,本发明实施例采用的技术方案如下:
第一方面,本发明实施例提供了一种任务处理方法,应用于客户终端,所述客户终端与调度服务器连接,所述调度服务器与多个任务服务器连接,所述方法包括:发送多个任务至所述调度服务器的数据池中;接收所述调度服务器为每个任务分配的唯一标识;根据每个任务的唯一标识从所述调度服务器的数据池中查询任务执行结果,所述任务执行结果由所述调度服务器根据预设的分配规则将多个任务发送至所述多个任务服务器,并由所述多个任务服务器执行多个任务得到任务结果后发送至调度服务器的数据池。
第二方面,本发明实施例还提供了一种任务调度方法,应用于调度服务器,所述调度服务器与客户终端与多个任务服务器均连接,所述方法包括:接收所述客户终端发送的多个任务并将接收的多个任务写入所述调度服务器的数据池中;为每个任务分配唯一标识,并将多个所述唯一标识发送至所述客户终端;按照预设的分配规则将所述多个任务发送至所述多个任务服务器;接收所述多个任务服务器执行所述多个任务后得到的任务执行结果,以供所述客户终端根据每个任务的唯一标识符从所述调度服务器的数据池中查询所述任务执行结果。
第三方面,本发明实施例还提供了一种任务处理装置,应用于客户终端,所述客户终端与调度服务器连接,所述调度服务器与多个任务服务器连接,所述装置包括:第一发送模块,用于发送多个任务至所述调度服务器的数据池中;第一接收模块,用于接收所述调度服务器为每个任务分配的唯一标识;查询模块,用于根据每个任务的唯一标识从所述调度服务器的数据池中查询任务执行结果,所述任务执行结果由所述调度服务器根据预设的分配规则将多个任务发送至所述多个任务服务器,并由所述多个任务服务器执行多个任务得到任务结果后发送至调度服务器的数据池。
第四方面,本发明实施例提供的一种任务调度装置,应用于调度服务器,所述调度服务器与客户终端与多个任务服务器均连接,所述装置包括:写入模块,用于接收所述客户终端发送的多个任务并将接收的多个任务写入所述调度服务器的数据池中;分配模块,用于为每个任务分配唯一标识,并将多个所述唯一标识发送至所述客户终端;第二发送模块,用于按照预设的分配规则将所述多个任务发送至所述多个任务服务器;第二接收模块,用于接收所述多个任务服务器执行所述多个任务后得到的任务执行结果,以供所述客户终端根据每个任务的唯一标识符从所述调度服务器的数据池中查询所述任务执行结果。
本发明实施例提供的一种任务处理方法及装置、任务调度方法及装置,该任务处理方法应用于客户终端,该客户终端与调度服务器连接,该调度服务器与多个任务服务器均连接。其中,客户终端发送多个任务至调度服务器的数据池中,由调度服务器对每个任务分配唯一标识并将多个任务的唯一标识发送至客户终端,此外,该调度服务器还按照预设的分配规则将多个任务发送至多个任务服务器,由任务服务器执行多个任务得到任务执行结果,进而将任务执行结果反馈至调度服务器的数据池中供客户终端根据任务的唯一标识进行查询。本方案中,通过对多个任务的并发执行,提高了任务处理速度,同时由多个任务服务器分别对任务进行处理,也极大地减少了任务服务器的压力。
为使本发明的上述目的、特征和优点能更明显易懂,下文特举较佳实施例,并配合所附附图,作详细说明如下。
附图说明
为了更清楚地说明本发明实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本发明的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
图1示出了本发明实施例提供的一种应用场景的示意图。
图2示出了本发明实施例提供的一种任务处理方法的流程示意图。
图3示出了本发明实施例提供的一种任务调度方法的流程示意图。
图4示出了本发明实施例提供的一种任务处理装置的功能模块示意图。
图5示出了本发明实施例提供的一种任务调度装置的功能模块示意图。
图示:100-客户终端;200-调度服务器;300-任务服务器;10-任务处理装置;20-任务调度装置;110-第一发送模块;120-第一接收模块;130-第一标记模块;140-查询模块;210-写入模块;220-分配模块;230-第二标记模块;240-第二发送模块;250-第二接收模块。
具体实施方式
下面将结合本发明实施例中附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。通常在此处附图中描述和示出的本发明实施例的组件可以以各种不同的配置来布置和设计。因此,以下对在附图中提供的本发明的实施例的详细描述并非旨在限制要求保护的本发明的范围,而是仅仅表示本发明的选定实施例。基于本发明的实施例,本领域技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本发明保护的范围。
应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。同时,在本发明的描述中,术语“第一”、“第二”等仅用于区分描述,而不能理解为指示或暗示相对重要性。
该PHP是一种HTML内嵌式的语言,其被编程人员广泛使用以实现编辑动态网页。由于传统的PHP只能通过串行的方式依次执行多个业务流程,因此需要消耗大量的业务执行时间,同时加大了服务器的压力。由此,本发明实施例提供一种任务处理方法以实现对客户终端发送的多个任务可以并发执行,以减少业务执行时间,此外,本发明实施例还提供一种业务调度方法以实现调度服务器可以对客户终端发起的多个任务按照预设规则分配给任务服务器处理,进而减小任务服务器的压力。
请参照图1,是本发明实施例提供的一种应用场景的示意图,其包括客户终端100、调度服务器200以及多个任务服务器300,该客户终端100与调度服务器200连接,该调度服务器200与多个任务服务器300连接,其中,客户终端100可以是,但不限于,手机、电脑等智能电子设备。本发明实施例提供的任务处理方法应用于客户终端100,本发明实施例提供的一种任务调度方法应用于调度服务器200。
请参照图2,是本发明实施例提供的一种任务处理方法的流程示意图,该方法包括:
步骤S110,发送多个任务至所述调度服务器的数据池中。
该调度服务器200内设置有数据池,该数据池的结构为structmultiprocess_task_listmultiprocess_task task;},其中multiprocess_task表征接收的由客户终端100发送的任务,task为任务名称。该单个任务在数据池的数据结构为:structmultiprocess_task{zend_uchartask_identify;zend_uchartask_type;zend_uintis_complete;zend_uchar data;};其中,task_identify表征每个任务的唯一标识,该唯一标识由调度服务器200接收到客户终端100发送的多个任务后,为每个任务进行分配;task_type为接收的任务类型;is_complete为任务的处理状态,即是否完成,当调度服务器200接收多个任务时,每个任务对应的is_complete的初始化值为0并由调度服务器200对任务进行监控;data为任务执行结果。该客户终端100multiprocess_task_write()方法将需要执行的多个任务依次写入调度服务器200的数据池中,即每个任务将写入数据结构中,且每个任务将有对应的一个数据结构进行表示。
步骤S120,接收所述调度服务器为每个任务分配的唯一标识。
当调度服务器200接收到客户终端100发送的多个任务后,将为每个任务随机分配唯一标识,如若客户终端100发送任务A、任务B、任务C至调度服务器200后,该调度服务器200将为每个任务随机分配唯一标识,如任务A唯一标识为3d6e3c19b2c4f2b66b7671877d9d9782,任务B唯一标识为1cb503f1dadccb0b3fc74f758babea39,任务C唯一标识为d288b9f5eaad4d7416ab737ba03198d9。
需要说明的是,该客户终端100还对每个任务的初始状态标记为未完成状态,具体实现方式为:$dy_multiprocess_task=array(‘3d6e3c19b2c4f2b66b7671877d9d9782’=>,‘1cb503f1dadccb0b3fc74f758babea39’=>0,‘3d6e3c19b2c4f2b66b7671877d9d9782’=>0)即是说,根据每个任务的唯一标识将每个任务的初始状态表征为0,即用0表征对应任务处于未完成状态。
步骤S130,根据每个任务的唯一标识从所述调度服务器的数据池中查询任务执行结果,所述任务执行结果由所述调度服务器根据预设的分配规则将多个任务发送至所述多个任务服务器,并由所述多个任务服务器执行多个任务得到任务结果后发送至调度服务器的数据池。
该调度服务器200接收到客户终端100发送的多个任务后,将该多个任务按照预定的分配规则发送至多个任务服务器300中。该预定的分配规则包括按照所述多个任务服务器负载情况,优先分配负载较小的人物服务器、按照所述多个任务服务器的性能权重排序,优先分配性能权重排序靠前的任务服务器以及按照所述多个任务服务器对应的任务类型进行分配。当按照多个任务服务器对应的任务类型进行分配任务时,如其中一部分任务服务器300的CPU性能更好,则优先分配复杂的计算,若其中一部分任务服务器300的带宽比较大,则优先分配执行发起外网http请求或者发起socket请求的任务。通过根据多个任务服务器300的实际工作情况对任务服务器300分配任务,极大地减少了任务服务器300的压力,同时提高了任务执行效率。
进而,该任务服务器300执行接收到的任务,如若该客户终端100发起的任务为查询北京当天的天气,则该任务服务器300执行该任务后得到的任务执行结果为北京、21度、东风、3级等天气结果。该多个任务服务器300分别对各自接收到的任务执行得到任务执行结果后,将该多个任务执行结果发送至调度服务器200的数据池中。该调度服务器200接收到任务执行结果后,将相应的任务的任务状态更改为已完成,即是将is_complete由初始值0变更为1,即是说1表征为对应任务已完成,同时将任务执行结果赋值于对应的data中。
进而,该客户终端100根据每个任务的唯一标识从调度服务器200的数据池中查询对应任务的任务执行结果,并在客户终端100进行显示。该客户终端100从调度服务器200的数据池中进行数据查询时的时间间隔可以自定义设置,较优地,该查询的时间间隔为1-10S。此外,该客户终端100将得到任务执行结果的任务在内部的状态对应更改为已完成,即是将$dy_multiprocess_task中所有任务的状态更改为1,1表征该任务的状态为已完成。当该客户终端100内的所有任务的任务状态均处于已完成时,该客户终端100可继续执行其他业务操作。
由此,通过本方案对多个任务并发执行,使得极大地减少了业务的操作时间。如若任务A执行时间为1S,任务B的执行时间为1.5S,任务C的执行时间为1.2S,则传统串行的执行时间和为多个任务执行时间的总和,即为3.7秒,但是对于本方案而言,其总的执行时间为多个任务对应的执行时间中最大的一个执行时间1.5S,相对于而言本方案的耗时减小了64.87%,其对于高并发的情况非常实用。
请参照图3,是本发明实施例提供的一种任务调度方法的流程示意图,该方法包括:
步骤S210,接收所述客户终端发送的多个任务并将接收的多个任务写入所述调度服务器的数据池中。
该调度服务器200内设置有数据池,该数据池的结构为structmultiprocess_task_listmultiprocess_task task;},其中multiprocess_task表征接收的由客户终端100发送的任务,task为任务名称。该单个任务在数据池的数据结构为:structmultiprocess_task{zend_uchartask_identify;zend_uchartask_type;zend_uintis_complete;zend_uchar data;};其中,task_identify表征每个任务的唯一标识,该唯一标识由调度服务器200接收到客户终端100发送的多个任务后,为每个任务进行分配;task_type为接收的任务类型;is_complete为任务的处理状态,即是否完成,当调度服务器200接收多个任务时,每个任务对应的is_complete的初始化值为0并由调度服务器200对任务进行监控;data为任务执行结果。该客户终端100multiprocess_task_write()方法将需要执行的多个任务依次写入调度服务器200的数据池中,即每个任务将写入数据结构中,且每个任务将有对应的一个数据结构进行表示。
步骤S220,为每个任务分配唯一标识,并将多个所述唯一标识发送至所述客户终端。
当调度服务器200接收到客户终端100发送的多个任务后,将为每个任务随机分配唯一标识,如若客户终端100发送任务A、任务B、任务C至调度服务器200后,该调度服务器200将为每个任务随机分配唯一标识,如任务A唯一标识为3d6e3c19b2c4f2b66b7671877d9d9782,任务B唯一标识为1cb503f1dadccb0b3fc74f758babea39,任务C唯一标识为d288b9f5eaad4d7416ab737ba03198d9。
步骤S230,按照预设的分配规则将所述多个任务发送至所述多个任务服务器。
该调度服务器200接收到客户终端100发送的多个任务后,将该多个任务按照预定的分配规则发送至多个任务服务器300中。该预定的分配规则包括按照所述多个任务服务器负载情况,优先分配负载较小的人物服务器、按照所述多个任务服务器的性能权重排序,优先分配性能权重排序靠前的任务服务器以及按照所述多个任务服务器对应的任务类型进行分配。当按照多个任务服务器对应的任务类型进行分配任务时,如其中一部分任务服务器300的CPU性能更好,则优先分配复杂的计算,若其中一部分任务服务器300的带宽比较大,则优先分配执行发起外网http请求或者发起socket请求的任务。通过根据多个任务服务器300的实际工作情况对任务服务器300分配任务,极大地减少了任务服务器300的压力,同时提高了任务执行效率。
步骤S240,接收所述多个任务服务器执行所述多个任务后得到的任务执行结果,以供所述客户终端根据每个任务的唯一标识符从所述调度服务器的数据池中查询所述任务执行结果。
该任务服务器300执行接收到的任务,如若该客户终端100发起的任务为查询北京当天的天气,则该任务服务器300执行该任务后得到的任务执行结果为北京、21度、东风、3级等天气结果。该多个任务服务器300分别对各自接收到的任务执行得到任务执行结果后,将该多个任务执行结果发送至调度服务器200的数据池中,以供客户终端100进行查询。该调度服务器200接收到任务执行结果后,将相应的任务的任务状态更改为已完成,即是将is_complete由初始值0变更为1,即是说1表征为对应任务已完成,同时将任务执行结果赋值于对应的data中。
请参照图4,是本发明实施例提供的一种任务处理装置10的功能模块示意图,该装置包括第一发送模块110、第一接收模块120、第一标记模块130以及查询模块140。
第一发送模块110,用于发送多个任务至所述调度服务器的数据池中。
在本发明实施例中,步骤S110可以由第一发送模块110执行。
第一接收模块120,用于接收所述调度服务器为每个任务分配的唯一标识。
在本发明实施例中,步骤S120可以由第一接收模块120执行。
第一标记模块130,用于标记每个任务的初始状态为未完成状态;
根据每个任务的唯一标识从所述调度服务器的数据池中查询任务的完成状态,若任务已完成,则将任务变更为已完成状态。
查询模块140,用于根据每个任务的唯一标识从所述调度服务器的数据池中查询任务执行结果,所述任务执行结果由所述调度服务器根据预设的分配规则将多个任务发送至所述多个任务服务器,并由所述多个任务服务器执行多个任务得到任务结果后发送至调度服务器的数据池。
在本发明实施例中,步骤S130可以有查询模块140执行。
由于在任务处理方法已经详细描述,在此不再赘述。
请参照图5,是本发明实施例提供的一种任务调度装置20的功能模块示意图,该装置包括:写入模块210、分配模块220、第二标记模块230、第二发送模块240、第二接收模块250。
写入模块210,用于接收所述客户终端发送的多个任务并将接收的多个任务写入所述调度服务器的数据池中。
在本发明实施例中,步骤S210可以由写入模块210执行。
分配模块220,用于为每个任务分配唯一标识,并将多个所述唯一标识发送至所述客户终端。
在本发明实施例中,步骤S220可以由分配模块220执行。
第二标记模块230,用于当将接收的多个任务写入所述调度服务器的数据池时,标记所述多个任务的初始状态为未完成状态。
当接收到所述任务的任务执行结果时,标记唯一标识对应的任务为已完成状态。
第二发送模块240,用于按照预设的分配规则将所述多个任务发送至所述多个任务服务器。
在本发明实施例中,步骤S230可以由第二发送模块240执行。
第二接收模块250,用于接收所述多个任务服务器执行所述多个任务后得到的任务执行结果,以供所述客户终端根据每个任务的唯一标识符从所述调度服务器的数据池中查询所述任务执行结果。
在本发明实施例中,步骤S240可以由第二接收模块250执行。
由于在任务调度方法部分已经详细描述,在此不再赘述。
综上所述,本发明实施例提供的一种任务处理方法及装置、任务调度方法及装置,该任务处理方法应用于客户终端,该客户终端与调度服务器连接,该调度服务器与多个任务服务器均连接。其中,客户终端发送多个任务至调度服务器的数据池中,由调度服务器对每个任务分配唯一标识并将多个任务的唯一标识发送至客户终端,此外,该调度服务器还按照预设的分配规则将多个任务发送至多个任务服务器,由任务服务器执行多个任务得到任务执行结果,进而将任务执行结果反馈至调度服务器的数据池中供客户终端根据任务的唯一标识进行查询。本方案中,通过对多个任务的并发执行,提高了任务处理速度,同时由多个任务服务器分别对任务进行处理,也极大地减少了任务服务器的压力。
在本申请所提供的几个实施例中,应该理解到,所揭露的装置和方法,也可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,附图中的流程图和框图显示了根据本发明的多个实施例的装置、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段或代码的一部分,所述模块、程序段或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现方式中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个连续的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或动作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
另外,在本发明各个实施例中的各功能模块可以集成在一起形成一个独立的部分,也可以是各个模块单独存在,也可以两个或两个以上模块集成形成一个独立的部分。
所述功能如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
以上所述仅为本发明的优选实施例而已,并不用于限制本发明,对于本领域的技术人员来说,本发明可以有各种更改和变化。凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。
以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应所述以权利要求的保护范围为准。
Claims (10)
1.一种任务处理方法,应用于客户终端,所述客户终端与调度服务器连接,所述调度服务器与多个任务服务器连接,其特征在于,所述方法包括:
发送多个任务至所述调度服务器的数据池中;
接收所述调度服务器为每个任务分配的唯一标识;
根据每个任务的唯一标识从所述调度服务器的数据池中查询任务执行结果,所述任务执行结果由所述调度服务器根据预设的分配规则将多个任务发送至所述多个任务服务器,并由所述多个任务服务器执行多个任务得到任务结果后发送至调度服务器的数据池。
2.如权利要求1所述的方法,其特征在于,所述方法还包括:
标记每个任务的初始状态为未完成状态;
根据每个任务的唯一标识从所述调度服务器的数据池中查询任务的完成状态,若任务已完成,则将任务变更为已完成状态。
3.一种任务调度方法,应用于调度服务器,所述调度服务器与客户终端与多个任务服务器均连接,其特征在于,所述方法包括:
接收所述客户终端发送的多个任务并将接收的多个任务写入所述调度服务器的数据池中;
为每个任务分配唯一标识,并将多个所述唯一标识发送至所述客户终端;
按照预设的分配规则将所述多个任务发送至所述多个任务服务器;
接收所述多个任务服务器执行所述多个任务后得到的任务执行结果,以供所述客户终端根据每个任务的唯一标识符从所述调度服务器的数据池中查询所述任务执行结果。
4.如权利要求3所述的方法,其特征在于,所述方法还包括:
当将接收的多个任务写入所述调度服务器的数据池时,标记所述多个任务的初始状态为未完成状态;
当接收到所述任务的任务执行结果时,标记唯一标识对应的任务为已完成状态。
5.如权利要求3所述的方法,其特征在于,所述预设的分配规则包括按照所述多个任务服务器负载情况,优先分配负载较小的人物服务器、按照所述多个任务服务器的性能权重排序,优先分配性能权重排序靠前的任务服务器以及按照所述多个任务服务器对应的任务类型进行分配。
6.一种任务处理装置,应用于客户终端,所述客户终端与调度服务器连接,所述调度服务器与多个任务服务器连接,其特征在于,所述装置包括:
第一发送模块,用于发送多个任务至所述调度服务器的数据池中;
第一接收模块,用于接收所述调度服务器为每个任务分配的唯一标识;
查询模块,用于根据每个任务的唯一标识从所述调度服务器的数据池中查询任务执行结果,所述任务执行结果由所述调度服务器根据预设的分配规则将多个任务发送至所述多个任务服务器,并由所述多个任务服务器执行多个任务得到任务结果后发送至调度服务器的数据池。
7.如权利要求6所述的装置,其特征在于,所述装置还包括:
第一标记模块,用于标记每个任务的初始状态为未完成状态;
根据每个任务的唯一标识从所述调度服务器的数据池中查询任务的完成状态,若任务已完成,则将任务变更为已完成状态。
8.一种任务调度装置,应用于调度服务器,所述调度服务器与客户终端与多个任务服务器均连接,其特征在于,所述装置包括:
写入模块,用于接收所述客户终端发送的多个任务并将接收的多个任务写入所述调度服务器的数据池中;
分配模块,用于为每个任务分配唯一标识,并将多个所述唯一标识发送至所述客户终端;
第二发送模块,用于按照预设的分配规则将所述多个任务发送至所述多个任务服务器;
第二接收模块,用于接收所述多个任务服务器执行所述多个任务后得到的任务执行结果,以供所述客户终端根据每个任务的唯一标识符从所述调度服务器的数据池中查询所述任务执行结果。
9.如权利要求8所述的装置,其特征在于,所述装置还包括:
第二标记模块,用于当将接收的多个任务写入所述调度服务器的数据池时,标记所述多个任务的初始状态为未完成状态;
当接收到所述任务的任务执行结果时,标记唯一标识对应的任务为已完成状态。
10.如权利要求8所述的装置,其特征在于,所述预设的分配规则包括按照所述多个任务服务器负载情况,优先分配负载较小的人物服务器、按照所述多个任务服务器的性能权重排序,优先分配性能权重排序靠前的任务服务器以及按照所述多个任务服务器对应的任务类型进行分配。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810002315.8A CN108228355A (zh) | 2018-01-02 | 2018-01-02 | 任务处理方法及装置、任务调度方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810002315.8A CN108228355A (zh) | 2018-01-02 | 2018-01-02 | 任务处理方法及装置、任务调度方法及装置 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN108228355A true CN108228355A (zh) | 2018-06-29 |
Family
ID=62642491
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810002315.8A Pending CN108228355A (zh) | 2018-01-02 | 2018-01-02 | 任务处理方法及装置、任务调度方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN108228355A (zh) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109495579A (zh) * | 2018-12-12 | 2019-03-19 | 万兴科技股份有限公司 | 任务处理方法、装置及系统 |
CN109634730A (zh) * | 2018-11-26 | 2019-04-16 | 平安科技(深圳)有限公司 | 任务调度方法、装置、计算机设备和存储介质 |
CN110162388A (zh) * | 2019-04-26 | 2019-08-23 | 深圳智链物联科技有限公司 | 一种任务调度方法、系统及终端设备 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103902646A (zh) * | 2013-12-27 | 2014-07-02 | 北京天融信软件有限公司 | 一种分布式任务管理系统与方法 |
CN104133724A (zh) * | 2014-04-03 | 2014-11-05 | 腾讯科技(深圳)有限公司 | 并发任务调度方法及装置 |
CN105786600A (zh) * | 2016-02-02 | 2016-07-20 | 北京京东尚科信息技术有限公司 | 任务调度方法和装置 |
CN107291547A (zh) * | 2016-03-31 | 2017-10-24 | 阿里巴巴集团控股有限公司 | 一种任务调度处理方法、装置及系统 |
-
2018
- 2018-01-02 CN CN201810002315.8A patent/CN108228355A/zh active Pending
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103902646A (zh) * | 2013-12-27 | 2014-07-02 | 北京天融信软件有限公司 | 一种分布式任务管理系统与方法 |
CN104133724A (zh) * | 2014-04-03 | 2014-11-05 | 腾讯科技(深圳)有限公司 | 并发任务调度方法及装置 |
CN105786600A (zh) * | 2016-02-02 | 2016-07-20 | 北京京东尚科信息技术有限公司 | 任务调度方法和装置 |
CN107291547A (zh) * | 2016-03-31 | 2017-10-24 | 阿里巴巴集团控股有限公司 | 一种任务调度处理方法、装置及系统 |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109634730A (zh) * | 2018-11-26 | 2019-04-16 | 平安科技(深圳)有限公司 | 任务调度方法、装置、计算机设备和存储介质 |
CN109634730B (zh) * | 2018-11-26 | 2024-05-31 | 平安科技(深圳)有限公司 | 任务调度方法、装置、计算机设备和存储介质 |
CN109495579A (zh) * | 2018-12-12 | 2019-03-19 | 万兴科技股份有限公司 | 任务处理方法、装置及系统 |
CN110162388A (zh) * | 2019-04-26 | 2019-08-23 | 深圳智链物联科技有限公司 | 一种任务调度方法、系统及终端设备 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20230376347A1 (en) | Task allocation method, apparatus, storage medium, and electronic device | |
CN108182111A (zh) | 任务调度系统、方法和装置 | |
CN105786600B (zh) | 任务调度方法和装置 | |
CN104915259A (zh) | 一种应用于分布式采集系统的任务调度方法 | |
US10783002B1 (en) | Cost determination of a service call | |
CN104156843A (zh) | 一种物流配送管理系统及其方法 | |
CN114244717B (zh) | 虚拟网卡资源的配置方法、装置、计算机设备及介质 | |
CN108228355A (zh) | 任务处理方法及装置、任务调度方法及装置 | |
CN109685301A (zh) | 资源管理方法、装置、设备及可读存储介质 | |
CN109426600B (zh) | 数据采集处理方法、装置、设备及可读存储介质 | |
CN106815254A (zh) | 一种数据处理方法和装置 | |
CN109189494B (zh) | 配置灰度发布方法、装置、设备及计算机可读存储介质 | |
CN105872082B (zh) | 基于容器集群负载均衡算法的细粒度资源响应系统 | |
CN109800078B (zh) | 一种任务处理方法、任务分发终端及任务执行终端 | |
CN113763043A (zh) | 广告落地页的展示方法、装置、存储介质及计算机设备 | |
CN116820714A (zh) | 一种算力设备的调度方法、装置、设备和存储介质 | |
CN107045452A (zh) | 虚拟机调度方法和装置 | |
CN113918305B (zh) | 节点调度方法、装置、电子设备及可读存储介质 | |
CN106294146B (zh) | 参数替换测试方法及装置 | |
CN106130757B (zh) | 信息获取方法和装置 | |
CN113055199B (zh) | 网关访问方法、装置及网关设备 | |
CN110019456A (zh) | 数据导入方法、装置和系统 | |
US20150263958A1 (en) | Load balancing apparatus and method | |
CN111782688A (zh) | 基于大数据分析的请求处理方法、装置、设备及存储介质 | |
CN109634827A (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 | ||
RJ01 | Rejection of invention patent application after publication | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20180629 |