任务分配方法及装置与流程

文档序号:11216046阅读:307来源:国知局
任务分配方法及装置与流程

本发明涉及数据处理领域,尤其涉及一种任务分配方法及装置。



背景技术:

任务分配是数据处理领域中的重要领域,合理的任务分配可以实现资源的优化配置,提升系统的整体效率。

但是,现有的任务分配方法的资源配置效率有待提升。



技术实现要素:

本发明解决的技术问题是提升任务分配方法的资源配置效率。

为解决上述技术问题,本发明实施例提供一种任务分配方法,包括:接收来自客户端的分配请求,所述分配请求包含用于标识所述客户端的来源标识;对所述来源标识进行验证,确定所述来源标识满足预设条件,所述预设条件包括:第一队列中未包含所述分配请求的来源标识;更新第一队列,将所述分配请求的来源标识添加至所述第一队列的尾部;按照先进先出的顺序,为所述第一队列中的所述来源标识指向的客户端分配待处理任务,所述待处理任务存储于第二队列中。

可选的,所述第二队列中存储有多个待处理任务,所述任务分配方法还包括:在所述分配待处理任务之后,将已分配的所述待处理任务从所述第二队列中移除。

可选的,为所述第一队列中的所述来源标识指向的客户端分配待处理任务包括:对位于所述第二队列首位的待处理任务和/或位于第一队列首位的来源标识进行锁定,直至分配完毕。

可选的,所述预设条件还包括:分配至所述来源标识指向的客户端的待处理任务的数量未超过上限。

可选的,为所述第一队列中的所述来源标识指向的客户端分配待处理任 务后,所述任务分配方法还包括:将所指向的客户端已分配到所述待处理任务的来源标识从所述第一队列中移除。

可选的,所述第二队列为先进先出队列。

本发明实施例中还提供一种任务分配装置,其特征在于,包括:分配请求接收单元,适于接收来自客户端的分配请求,所述分配请求包含所述用于标识客户端的来源标识;验证单元,适于对所述来源标识进行验证,确定所述来源标识满足预设条件,所述预设条件包括:第一队列中未包含所述分配请求的来源标识;更新单元,适于更新第一队列,将所述分配请求的来源标识添加至所述第一队列的尾部;分配单元,适于按照先进先出的顺序,为所述第一队列中的所述来源标识指向的客户端分配待处理任务,所述待处理任务存储于第二队列中。

可选的,所述第二队列中存储有多个待处理任务,所述任务分配装置还包括:第一移除单元,适于在所述分配待处理任务之后,将已分配的所述待处理任务从所述第二队列中移除。

可选的,所述分配单元包括锁定单元,适于对位于所述第二队列首位的待处理任务和/或位于第一队列首位的来源标识进行锁定,直至分配完毕。

可选的,所述预设条件还包括:分配至所述来源标识指向的客户端的待处理任务的数量未超过上限。

可选的,所述任务分配装置还包括:第二移除单元,适于所述第一队列中的所述来源标识指向的客户端分配待处理任务后,将所指向的客户端已分配到所述待处理任务的来源标识从所述第一队列中移除。

可选的,所述第二队列为先进先出队列。

与现有技术相比,本发明实施例的技术方案具有以下有益效果:

通过对来源标识进行验证,确定来源标识满足预设条件后,才将分配请求添加至第一队列的尾部,按照先进先出的顺序,为所述第一队列中的所述来源标识指向的客户端分配待处理任务。当第一队列中已包含分配请求指向的用户端的来源标识时,若将该来源标识添加至第一队列,会对该标识对应 的客户端进行任务的重复分配,而本发明实施例中的预设条件包括分配请求的来源标识未包含于第一队列中,在确定来源标识满足预设条件后,才将分配请求的来源标识添加至第一队列的尾部以进行后续的任务分配,由此,可以使得任务分配更加合理,避免同一客户端在任务分配过程中反复抢夺任务,从而可以优化客户端的资源配置。

附图说明

图1是本发明实施例中一种任务分配方法的流程图;

图2是本发明实施例中一种任务分配装置的结构示意图。

具体实施方式

如前所述,任务分配是数据处理领域中的重要领域,合理的任务分配可以实现资源的优化配置,提升系统的整体效率。但是,现有的任务分配方法的资源配置效率有待提升。

本发明实施例通过对来源标识进行验证,确定来源标识满足预设条件后,才将分配请求添加至第一队列的尾部,按照先进先出的顺序,为所述第一队列中的所述来源标识指向的客户端分配待处理任务。当第一队列中已包含分配请求指向的用户端的来源标识时,若将该来源标识来源添加至第一队列,会对该标识对应的客户端进行任务的重复分配,而本发明实施例中的预设条件包括分配请求的来源标识未包含于第一队列中,在确定来源标识满足预设条件后,才将分配请求的来源标识添加至第一队列的尾部以进行后续的任务分配,由此,可以使得任务分配更加合理,避免同一客户端在任务分配过程中反复抢夺任务,从而可以优化客户端的资源配置。

为使本发明的上述目的、特征和有益效果能够更为明显易懂,下面结合附图对本发明的具体实施例做详细的说明。

图1是本发明实施例中一种任务分配方法的流程图。

在步骤s11中,接收来自客户端的分配请求,所述分配请求包含用于标识所述客户端的来源标识。

客户端的分配请求可以是用户在客户端操作后生成;客户端的来源标识 对客户端起标识作用,例如可以是客户端对应用户的身份标识。

在步骤s12中,对所述来源标识进行验证,确定所述来源标识满足预设条件,所述预设条件包括:第一队列中未包含所述分配请求的来源标识。

第一队列中存储有待进行任务分配的来源标识,系统会按照先进先出的顺序为排在第一队列中的来源标识分配待处理任务。

由于对任务的处理需要客户端的资源,在所述第一队列中已包含分配请求的来源标识时,若再次将该分配请求的来源标识加入所述第一队列,并为该来源标识指向的客户端分配待处理任务,会使得该来源标识对应的客户端分配到更多的待处理任务,造成超出其处理能力的超负荷状态,而其他客户端不能合理的分配到待处理任务而资源空置,不利于各个客户端的资源优化配置。

由于所述预设条件包括所述第一队列中未包含所述分配请求的来源标识,仅在所述第一队列中未包含所述分配请求的来源标识时,才将所述分配请求的来源标识添加至所述第一队列的尾部,可以对各个客户端更合理的进行任务分配,优化各个客户端之间的资源配置。

在具体实施中,所述预设条件还可以包括:分配至所述来源标识指向的客户端的待处理任务的数量未超过上限。

每个客户端对待处理任务的处理能力受制于其资源限制,考虑到各个客户端之间的资源优化配置,可以设置客户端分配到的待处理任务的数量上限。每个客户端的待处理任务的数量上限可以是相同的,也可以是不同的,该上限可以根据每个客户端情况进行设置。

通过设置每个客户端分配到的待处理任务的上限,在服务器接收到来自客户端的分配请求时,对该客户端的待处理任务的数量进行判断,只有当其待处理任务的数量未超过上限时,才将其对应的来源标识添加至第一队列的尾部,从而可以均衡在各个客户端之间的任务分配,实现各个客户端之间的资源优化配置。

在步骤s13中,更新第一队列,将所述分配请求的来源标识添加至所述第一队列的尾部。

可以理解的是,对第一队列的更新可以包括当第一队列为空队列时,将所述分配请求的来源标识添加至所述第一队列。

在步骤s14中,按照先进先出的顺序,为所述第一队列中的所述来源标识指向的客户端分配待处理任务,所述待处理任务存储于第二队列中。

通过按照先进先出的顺序为所述第一队列中的所述来源标识指向的客户端分配待处理任务,可以公平的为第一队列中的来源标识指向的客户端分配任务,避免第一队列中的某个来源标识一直抢占队列,进而实现客户端之间的资源优化配置。

在具体实施中,所述第二队列可以是先进先出队列。位于第二队列中的待处理任务可以是各种不同类型的待处理任务,例如可以是交易数据处理任务。第二队列中的任务可以是根据申报建立的,例如申报客户端通过申报的方式将交易数据处理任务添加至第二队列中,以供分配。

在一具体实施中,所述第二队列中存储有多个待处理任务,所述任务分配方法还可以包括:在所述分配待处理任务之后,将已分配的所述待处理任务从所述第二队列中移除。

在另一具体实施中,为所述第一队列中的所述来源标识指向的客户端分配待处理任务后,所述任务分配方法还还可以包括:将所指向的客户端已分配到所述待处理任务的来源标识从所述第一队列中移除。

在具体实施中,为所述第一队列中的所述来源标识指向的客户端分配待处理任务可以包括:对位于所述第二队列首位的待处理任务和/或位于第一队列首位的来源标识进行锁定,直至分配完毕。

由于利用先进先出的方式对第一队列中的所述来源标识指向的客户端分配待处理任务,故对位于第一队列首位的来源标识进行锁定,只允许位于第一队列首位的来源标识接收一个任务分配,可以避免出现对一个来源标识对应的客户端多次分配待处理任务,实现各个客户端之间的资源优化配置。

同样地,对位于所述第二队列首位的待处理任务进行锁定,使其只能被分配至一个来源标识对应的客户端,可以避免单个待处理任务多次分配的问题。

对第一队列和/或第二队列的锁定可以利用key/value数据库redis实现。

在本发明一实施例中,任务分配方法还可以包括:在为所述第一队列中的所述来源标识指向的客户端分配待处理任务后,通知所述来源标识指向的客户端,以使得该客户端获知自己已经被分配待处理任务,从而可以及时进行处理。

通过对来源标识进行验证,确定来源标识满足预设条件后,才将分配请求添加至第一队列的尾部,按照先进先出的顺序,为所述第一队列中的所述来源标识指向的客户端分配待处理任务。由于预设条件包括在第一队列中未包含分配请求的来源标识,当第一队列中已包含分配请求指向的用户端的来源标识时,若将该标识来源添加至第一队列,会对该标识对应的客户端进行任务的重复分配,故确定来源标识满足预设条件后,才将分配请求添加至第一队列的尾部,可以使得任务分配更加合理,优化客户端的资源配置。

本发明实施例还提供一种任务分配装置,其结构示意图参见图2。

任务分配装置包括:分配请求接收单元21,适于接收来自客户端的分配请求,所述分配请求包含用于标识所述客户端的来源标识;

验证单元22,适于对所述来源标识进行验证,确定所述来源标识满足预设条件,所述预设条件包括:第一队列中未包含所述分配请求的来源标识;

更新单元23,适于更新第一队列,将所述分配请求的来源标识添加至所述第一队列的尾部;

分配单元24,适于按照先进先出的顺序,为所述第一队列中的所述来源标识指向的客户端分配待处理任务,所述待处理任务存储于第二队列中。

在具体实施中,所述第二队列中可以存储有多个待处理任务,所述任务分配装置还可以包括:第一移除单元,适于在所述分配待处理任务之后,将已分配的所述待处理任务从所述第二队列中移除。

在具体实施中,所述分配单元24可以包括锁定单元,适于对位于所述第二队列首位的待处理任务和/或位于第一队列首位的来源标识进行锁定,直至分配完毕。

在具体实施中,所述预设条件还可以包括:分配至所述来源标识指向的客户端的待处理任务的数量未超过上限。

在具体实施中,任务分配装置还可以包括:第二移除单元,适于所述第一队列中的所述来源标识指向的客户端分配待处理任务后,将所指向的客户端已分配到所述待处理任务的来源标识从所述第一队列中移除。

在具体实施中,所述第二队列可以为先进先出队列。

本领域普通技术人员可以理解上述实施例的各种方法中的全部或部分步骤是可以通过程序来指令相关的硬件来完成,该程序可以存储于一计算机可读存储介质中,存储介质可以包括:rom、ram、磁盘或光盘等。

虽然本发明披露如上,但本发明并非限定于此。任何本领域技术人员,在不脱离本发明的精神和范围内,均可作各种更动与修改,因此本发明的保护范围应当以权利要求所限定的范围为准。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1