CN114168290A - 一种任务处理方法、装置、电子设备及存储介质 - Google Patents
一种任务处理方法、装置、电子设备及存储介质 Download PDFInfo
- Publication number
- CN114168290A CN114168290A CN202111497221.0A CN202111497221A CN114168290A CN 114168290 A CN114168290 A CN 114168290A CN 202111497221 A CN202111497221 A CN 202111497221A CN 114168290 A CN114168290 A CN 114168290A
- Authority
- CN
- China
- Prior art keywords
- task
- target
- executed
- thread
- execution instruction
- 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
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
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
技术领域
本发明实施例涉及计算机技术领域,尤其涉及一种任务处理方法、装置、电子设备及存储介质。
背景技术
任务调度是操作系统中的重要组成部分,能够直接影响操作系统的实时性。
目前,在操作系统进行任务调度时,一般会根据不同的调度任务所需的执行时间设置相应的任务调度周期,而由于网络原因或资源设备的性能差异,可能会出现该调度任务的实际执行时间大于任务调度时间,而此时,系统可能会下发新的调度任务,导致出现任务调度阻塞,从而给资源设备造成性能负载的问题。
为了解决操作系统中的任务调度阻塞的问题,需要对任务调度的执行方法进行改进,以保证资源设备能够更好的执行任务。
发明内容
本发明提供一种任务处理方法、装置、电子设备及存储介质,以实现解决任务调度阻塞并减轻资源设备性能负载的效果。
第一方面,本发明实施例提供了一种任务处理方法,其特征在于,包括:
确定与目标待执行任务相对应的任务执行指令,并将所述任务执行指令发送至所述目标资源设备;其中,所述任务执行指令中包括执行所述目标待执行任务的目标资源设备以及任务调度周期;
基于所述目标资源设备接收所述任务执行指令,并启动与所述目标待执行任务相对应的任务线程;
基于所述任务线程和所述任务调度周期,确定所述目标待执行任务的处理结果。
第二方面,本发明实施例还提供了一种任务处理装置,其特征在于,包括:
指令发送模块,用于确定与目标待执行任务相对应的任务执行指令,并将所述任务执行指令发送至所述目标资源设备;其中,所述任务执行指令中包括执行所述目标待执行任务的目标资源设备以及任务调度周期;
任务线程启动模块,用于基于所述目标资源设备接收所述任务执行指令,并启动与所述目标待执行任务相对应的任务线程;
处理结果确定模块,用于基于所述任务线程和所述任务调度周期,确定所述目标待执行任务的处理结果。
第三方面,本发明实施例还提供了一种电子设备,所述电子设备包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如本发明实施例任一所述的任务处理方法。
第四方面,本发明实施例还提供了一种包含计算机可执行指令的存储介质,所述计算机可执行指令在由计算机处理器执行时用于执行如本发明实施例任一所述的任务处理方法。
本实施例的技术方案,确定与目标待执行任务相对应的任务执行指令,并将所述任务执行指令发送至所述目标资源设备;其中,所述任务执行指令中包括执行所述目标待执行任务的目标资源设备以及任务调度周期,由目标资源设备根据任务执行指令,启动与目标待执行任务相对应的任务线程,并对目标待执行任务进行处理。基于所述目标资源设备接收所述任务执行指令,并启动与所述目标待执行任务相对应的任务线程,用于基于目标资源设备中的任务线程以及目标待执行任务的任务调度周期,确定任务线程是否在任务调度周期内完成任务。基于所述任务线程和所述任务调度周期,确定所述目标待执行任务的处理结果,确定目标资源设备的任务状态,然后根据处理结果可以根据对任务线程进行释放操作,或者将新的执行任务发送给任务状态为空闲状态的资源设备。解决了当操作系统中的有多个执行任务需要被处理,可能会出现任务调度阻塞,进而导致对资源设备造成性能负载的问题,实现了对各资源设备进行合理的任务调度,解决任务调度阻塞并减轻资源设备性能负载的效果。
附图说明
为了更加清楚地说明本发明示例性实施例的技术方案,下面对描述实施例中所需要用到的附图做一简单介绍。显然,所介绍的附图只是本发明所要描述的一部分实施例的附图,而不是全部的附图,对于本领域普通技术人员,在不付出创造性劳动的前提下,还可以根据这些附图得到其他的附图。
图1为本发明实施例一所提供的一种任务处理方法的流程示意图;
图2为本发明实施例二所提供的一种任务处理方法的流程示意图;
图3为本发明实施例三所提供的一种任务处理方法的流程示意图;
图4为本发明实施例四所提供的一种任务处理装置的结构示意图。
图5为本发明实施例五所提供的一种电子设备的结构示意图。
具体实施方式
下面结合附图和实施例对本发明作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释本发明,而非对本发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与本发明相关的部分而非全部结构。
为了能够更好的理解本方案,在对本技术方案进行详细阐述之前,先对本技术方案进行简单介绍。
任务调度是操作系统的重要组成部分,尤其是对于实时操作系统,任务调度直接影响操作系统的实时性能。任务调度可以理解为操作系统分配任务所需要的资源的操作,这里所说的任务可以为对系统中的文件进行扫描或者执行用户自定义的某些程序、命令或线程资源等,还可以指操作系统中的各种任务的执行等。对于操作系统中的某些任务需要在特定的时间进行周而复始的执行,例如病毒扫描等;或者是个别用户工作,例如可以为用户自定义执行某些程序等。任务调度可以根据操作系统中的默认设置或是用户的设置,每隔一段时间执行一次,也可以是周期性的对操作系统中的任务进行调度。
实施例一
图1为本发明实施例一所提供的一种任务处理方法流程示意图,本实施例可适用于避免资源设备在执行调度任务时出现任务调度阻塞的情况,该方法可以由任务处理装置来执行,该装置可以通过软件和/或硬件的形式实现,硬件可以是电子设备,如,移动终端或PC端等。
如图1所示,该方法包括:
S110、确定与目标待执行任务相对应的任务执行指令,并将所述任务执行指令发送至所述目标资源设备;其中,所述任务执行指令中包括执行所述目标待执行任务的目标资源设备以及任务调度周期。
其中,目标待执行任务可以理解为在操作系统在进行任务调度时即将被调度执行的任务。任务执行指令可以理解为用于指示目标资源设备执行任务的指令,在任务执行指令中包含目标待执行任务的相关信息,例如可以包括目标待执行任务的目标资源设备以及任务调度周期等信息,还可以包括目标待执行任务的名称、与目标待执行任务相对应的标识性信息、目标待执行任务的执行时长以及执行周期等信息。任务执行指令可以由操作系统中的调度中心发送给目标资源设备,目标资源设备在接收到任务执行指令后,可以根据该任务执行指令执行目标待执行任务。调度中心可以理解为操作系统中的任务调度核心组件,可以负责各任务的整体生命流程以及任务的分配下发等。资源设备可以理解为用于执行调度中心下发的任务的设备,也可以被称为执行节点,目标资源设备可以理解为用于执行目标待执行任务的设备。
具体的,在需要进行任务调度时,首先操作系统或人工确定目标待执行任务,根据目标待执行任务的相关信息,可以生成与目标待执行任务相对应的任务执行指令。然后调度中心可以将任务执行指令发送给目标资源设备,由目标资源设备根据任务执行指令执行目标待执行任务。
可选的,所述确定与目标待执行任务相对应的任务执行指令,并将所述任务执行指令发送至所述目标资源设备,包括:从第一数据表中获取所述目标待执行任务的任务调度周期;其中,所述第一数据表中包括至少一个待执行任务和与各待执行任务相对应的任务调度周期;从第二数据表中获取与所述目标待执行任务相对应的目标资源设备;其中,所述第二数据表中包括执行节点和所述执行节点的任务状态;所述执行节点与资源设备相对应。
其中,第一数据表可以理解为操作系统中数据库中用于记录各任务的基本配置列表,例如任务的执行时长和调度周期等第一数据表例如可以为数据库表中的task_info表。操作系统中的某些任务需要周期性的进行执行,例如对文件进行定期扫描,任务调度周期可以理解为操作系统中各任务的执行周期,各个任务的调度周期不完全相同,例如可以为每隔5分钟被执行一次,也可以为每隔1小时执行一次,或者每隔1天执行一次等,在此不做具体限定。第二数据表可以理解为操作系统中数据库中用于保存资源设备的列表,第二数据表例如可以为task_executor_list表,在第二数据表中包括各执行节点的任务状态,且各执行节点与各资源设备相对应。需要说明的是,本技术方案中提及的“第一”、“第二”等概念仅用于对操作系统的数据库中不同的列表进行区分,并非用于限定对这些列表的限定。
具体的,在第一数据表中包括至少一个待执行任务以及与各待执行任务相对应的任务调度周期,基于第一数据表中存储的各待执行任务的相关信息,可以查询并获取目标待执行任务以及与目标待执行任务的任务调度周期。然后从第二数据表中预先存储了各待执行任务所对应的资源设备,并将于目标待执行任务相对应的资源设备作为目标资源设备,基于相对应的各资源设备,可以执行各待执行任务。需要说明的是,执行节点与资源设备相对应,在第二数据表中还包括执行节点当期的任务状态,例如该执行节点是否为空闲状态,或者该执行节点当前执行的任务所需时长,以及可以处理新的任务的具体时间点等。
可选的,所述任务状态包括空闲状态和忙碌状态,所述从第二数据表中获取与所述目标待执行任务相对应的目标资源设备,包括:从所述第二数据表中获取所述任务状态为空闲状态的目标资源设备。
其中,空闲状态可以理解为资源设备当前正在执行的任务已完成,处于可以执行新任务的状态。忙碌状态可以理解为资源设备当前正在执行任务,无法执行新任务的状态。
具体的,一般来说,资源设备在执行任务时,若同时执行多个任务,会对资源设备造成性能负载的问题,为了避免各资源设备同时执行多个任务,需要根据各资源设备当前的任务状态进行分配。在第二数据表中可以记录与各资源设备的任务状态,为了合理的各个资源设备分配执行任务,使各资源设备能够更好地运行,在调度中心给各资源设备分配任务时,预先在第二数据表中查询各资源设备的任务状态,确定各资源设备处于空闲状态还是忙碌状态,将处于空闲状态的资源设备作为目标资源设备,然后将任务分配给目标资源设备执行。
S120、基于所述目标资源设备接收所述任务执行指令,并启动与所述目标待执行任务相对应的任务线程。
其中,在资源设备的操作系统中,包括进程机制和线程机制,进程可以理解为操作系统在进行资源分配和调度的一个独立单位,线程可以理解为进程中的执行单元,任务线程可以理解为资源设备中对目标待执行任务进行处理的线程,任务线程可以为FutureTask线程。
具体的,目标资源设备在接收到任务执行指令后,基于任务执行指令启动与目标待执行任务相对应的任务线程,由目标资源设备中的任务线程对目标待执行任务进行处理。
可选的,所述基于所述目标资源设备接收所述任务执行指令,并启动与所述目标待执行任务相对应的任务线程,包括:基于目标资源设备接收所述任务执行指令时,向目标系统发送线程建立请求;基于所述目标系统接收所述线程建立请求,并创建与所述目标待执行任务相对应的任务线程。
其中,目标系统可以理解为目标资源设备的操作系统。线程建立请求可以理解为一个请求指令,用于向目标系统申请建立与目标待执行任务相对应的任务线程。
具体的,目标资源设备在接收到任务执行指令时,若想要执行与任务执行指令相对应的目标待执行任务,需要通过目标系统中的线程进行执行操作,因此需要在接收到任务执行指令时,向目标系统发送线程建立请求。目标系统在接收到线程建立请求后,可以根据任务执行指令中的目标待执行任务的相关信息,创建与目标待执行任务相对应的任务线程。
S130、基于所述任务线程和所述任务调度周期,确定所述目标待执行任务的处理结果。
具体的,目标待执行任务所对应的任务执行指令中包含了目标待执行任务所对应的目标资源设备,以及目标待执行任务的任务调度周期。相应的,基于任务执行指令发送的线程建立请求中,也包含目标待执行任务的任务调度周期,基于线程建立请求创建任务线程后,基于任务线程和任务调度周期处理目标待执行任务,并确定目标待执行任务的处理结果,例如已完成任务或未完成任务等。
本实施例的技术方案,确定与目标待执行任务相对应的任务执行指令,并将所述任务执行指令发送至所述目标资源设备;其中,所述任务执行指令中包括执行所述目标待执行任务的目标资源设备以及任务调度周期,由目标资源设备根据任务执行指令,启动与目标待执行任务相对应的任务线程,并对目标待执行任务进行处理。基于所述目标资源设备接收所述任务执行指令,并启动与所述目标待执行任务相对应的任务线程,用于基于目标资源设备中的任务线程以及目标待执行任务的任务调度周期,确定任务线程是否在任务调度周期内完成任务。基于所述任务线程和所述任务调度周期,确定所述目标待执行任务的处理结果,确定目标资源设备的任务状态,然后根据处理结果可以根据对任务线程进行释放操作,或者将新的执行任务发送给任务状态为空闲状态的资源设备。解决了当操作系统中的有多个执行任务需要被处理,可能会出现任务调度阻塞,进而导致对资源设备造成性能负载的问题,实现了对各资源设备进行合理的任务调度,解决任务调度阻塞并减轻资源设备性能负载的效果。
实施例二
作为上述实施例的一可选实施例,图2为本发明实施例二所提供的一种任务处理方法的流程示意图,可选的,对所述基于所述任务线程和所述任务调度周期,确定所述目标待执行任务的处理结果进行细化。
如图2所示,该方法包括:
S210、确定与目标待执行任务相对应的任务执行指令,并将所述任务执行指令发送至所述目标资源设备;其中,所述任务执行指令中包括执行所述目标待执行任务的目标资源设备以及任务调度周期。
S220、基于所述目标资源设备接收所述任务执行指令,并启动与所述目标待执行任务相对应的任务线程。
S230、基于目标监听函数,确定所述任务线程的持续时长。
其中,目标监听函数可以理解为任务线程中的监听函数,可以用于监听任务线程的执行状态,例如持续时长,以及在任务调度周期内目标待执行任务是否被完成等,例如,目标监听函数可以为FutureTask.get(T)函数。任务线程的持续时长可以理解为自任务线程被建立的时刻起,处理目标待执行任务的时长。
具体的,在任务线程被建立后,任务线程开始对目标待执行任务进行处理,在任务线程的处理过程中,任务线程中的目标监听函数可以对任务线程的处理状态进行监听,基于目标监听函数的监听结果,可以确定任务线程自建立起,处理目标待执行任务的持续时长,进一步的,还可以根据持续时长确定任务线程是否在任务调度周期内完成任务。
S240、若所述持续时长小于所述任务调度周期,则确定所述目标待执行任务的处理结果为完成任务。
具体的,基于任务线程对目标待执行任务进行处理的处理结果可以包括两种:完成任务和未完成任务。通常调度中心在给各资源设备分配调度任务时,会预先获取该调度任务的任务调度周期,即运行该调度任务所需的最大执行时长,执行时长可以与任务调度周期相等,也可以大于任务调度周期,以保证任务线程能够在任务调度周期内完成任务。例如执行某调度任务所需的时长为3分钟,则对应的任务调度周期可以为3分钟,也可以为5分钟,但是不能小于3分钟,以调度周期为5分钟为例,自任务线程被建立起,5分钟后,操作系统默认任务线程已完成任务,可以向该线程分配新的调度任务。为了确定调度任务在任务调度周期内是否被完成,为了确定调度任务的实际执行时间,可以通过目标监听函数监听任务线程处理目标待执行任务的持续时间,若监听的结果为任务线程的持续时间小于目标待执行任务的任务调度周期,则表示任务线程在任务调度周期内完成了目标待执行任务,此时,若有新的任务需要进行处理,则该调度中心将优先将任务分配给该任务线程所对应的资源设备进行处理。
可选的,若所述持续时长大于等于所述任务调度周期,则将所述任务线程释放,并确定所述目标待执行任务的处理结果为未完成任务,并向目标终端设备发送预警信息。
其中,目标终端设备可以理解为调度中心所对应的终端设备。预警信息可以理解为在目标待执行任务未被完成时,可以向目标终端发送的用于提示的信息,例如可以为“任务执行异常”或“任务执行失败”等信息。
具体的,在任务线程对目标待执行任务进行处理的过程中,可能会受到网络或资源设备性能的影响,当网络速度较慢,或者资源设备性能低时,会对目标待执行任务的处理速度造成影响,导致在调度周期内没有完成调度任务的情况,但是当任务调度周期结束后,系统或默认任务线程已完成目标待执行任务,若此时有新的调度任务需要该任务线程进行处理,就会将新的调度任务分配给该任务线程,导致该任务线程需要同时处理两个或多个调度任务,出现任务调度阻塞的情况。也就是说,一般情况下,由于任务调度周期通常大于等于调度任务实际执行所需时长,若调度任务没有在任务调度周期内被完成,就会出现同一个线程需要处理多个调度任务的情况。为了避免任务线程同时处理多个调度任务的情况,当目标监听函数监听的结果为任务线程的持续时长大于目标待执行任务的任务调度周期,可以确定目标待执行任务的处理结果为未完成任务,此时需要向目标终端设备发送预警信息,以提醒设备人员根据预警信息进行处理。
示例性地,以目标待执行任务为任务A为例,当目标监听函数监听的结果为任务线程的持续时长大于任务A的任务调度周期,表明任务A的处理出现异常,而此时,调度中心需要将新的任务分配给目标资源设备进行处理,例如为将任务B分配给目标资源设备处理,那么此时就会出现目标设备中的任务线程需要同时对两个任务进行处理的问题,但如果任务线程同时处理两个或多个任务时,会给资源设备造成性能负载。在这种情况下,可以任务线程可以将任务A进行释放,终止任务A的继续执行,以执行任务B。其中,终止任务A的方法可以为通过FutureTask中的InterruptedException函数进进行终止任务A的继续执行。
或者,当目标监听函数监听的结果为任务线程的持续时长大于任务A的任务调度周期时,还可以向资源设备反馈任务线程的未完成的结果,并由资源设备向调度中心反馈资源设备的任务状态,调度中心在接收到反馈结果后,可以根据各资源设备的任务状态,优先将新的任务发送给处于空闲状态的资源设备进行处理。
可选的,将所述目标资源设备在第二数据表中的任务状态从忙碌状态更新为空闲状态。
具体的,当任务线程正在执行任务时,所对应的资源设备的任务状态为忙碌状态,相应的,当任务线程处于没有执行任务的状态时,所对应的资源设备的任务状态为空闲状态。当目标监听函数监听到任务线程已完成任务时,可以通知目标资源设备,并修改第二数据表中的任务状态,即,将第二数据表中的任务状态由忙碌状态更新为空闲状态。
本实施例的技术方案,基于目标监听函数,确定所述任务线程的持续时长,然后根据持续时长可以确定任务线程是否完成任务,若持续时长小于任务调度周期,表明目标待执行任务在任务调度周期内被完成,目标资源设备的任务状态为空闲状态,可执行新的调度任务;若持续时长大于任务调度周期,则表示目标待执行任务在任务调度周期内没有被完成,此时目标资源设备的任务状态为忙碌状态,可以通过任务线程内的函数将正在执行的调度任务的任务线程进行释放,或者优先将调度任务发送给任务状态为空闲状态的资源设备,以处理新的调度任务。解决了在任务线程在任务调度周期内没有完成任务时,目标资源设备可能需要同时执行多个调度任务的问题,实现了根据目标资源当前的任务状态,由调度中心合理的给各资源设备分配任务的效果。
实施例三
在一个具体的例子中,如图3所示,调度中心可以将各调度任务分配给相应的资源设备,由资源设备中的任务线程对调度任务进行处理。在分配调度任务之前,调度中心可以在task_info表(即,第一数据表)中查询目标待执行任务的调度周期T。然后调度中心从task_executor_list表(即,第二数据表)中选择出执行节点(即,目标资源设备)发送线程建立请求,在该线程建立请求中包含与目标待执行任务相对应的任务调度周期T,然后目标资源设备在接收到该请求后,可以建立FutureTask线程(即,任务线程),用以处理目标待执行任务。在处理目标待执行任务的过程中,FutureTask线程中的FutureTask.get(T)(即,目标监听函数)可以持续监听任务线程的持续时长,并确定任务线程在目标待执行任务调度周期内是否完成任务,若完成任务,则将处理结果发送给调度中心,以便调度中心可以将新的调度任务发送给相对应的资源设备进行处理。若处理结果为未完成,则此时该资源设备的任务状态为忙碌状态,向调度中心反馈异常(即,发送预警信息)。然后FutureTask线程可以通过InterruptedException函数将任务线程进行释放,终止目标待执行任务的继续运行,同时将目标资源设备的任务状态从忙碌状态改为空闲状态。或者调度中心在接收到预警信息后,可以优先将新的调度任务发送给任务状态为空闲状态的资源设备。
本实施例的技术方案,确定与目标待执行任务相对应的任务执行指令,并将所述任务执行指令发送至所述目标资源设备;其中,所述任务执行指令中包括执行所述目标待执行任务的目标资源设备以及任务调度周期,由目标资源设备根据任务执行指令,启动与目标待执行任务相对应的任务线程,并对目标待执行任务进行处理。基于所述目标资源设备接收所述任务执行指令,并启动与所述目标待执行任务相对应的任务线程,用于基于目标资源设备中的任务线程以及目标待执行任务的任务调度周期,确定任务线程是否在任务调度周期内完成任务。基于所述任务线程和所述任务调度周期,确定所述目标待执行任务的处理结果,确定目标资源设备的任务状态,然后根据处理结果可以根据对任务线程进行释放操作,或者将新的执行任务发送给任务状态为空闲状态的资源设备。解决了当操作系统中的有多个执行任务需要被处理,可能会出现任务调度阻塞,进而导致对资源设备造成性能负载的问题,实现了对各资源设备进行合理的任务调度,解决任务调度阻塞并减轻资源设备性能负载的效果。
实施例四
图4为本发明实施例四提供的一种任务处理装置,该装置包括:指令发送模块410、任务线程启动模块420和处理结果确定模块430。
其中,指令发送模块410,用于确定与目标待执行任务相对应的任务执行指令,并将所述任务执行指令发送至所述目标资源设备;其中,所述任务执行指令中包括执行所述目标待执行任务的目标资源设备以及任务调度周期;
任务线程启动模块420,用于基于所述目标资源设备接收所述任务执行指令,并启动与所述目标待执行任务相对应的任务线程;
处理结果确定模块430,用于基于所述任务线程和所述任务调度周期,确定所述目标待执行任务的处理结果。
本实施例的技术方案,确定与目标待执行任务相对应的任务执行指令,并将所述任务执行指令发送至所述目标资源设备;其中,所述任务执行指令中包括执行所述目标待执行任务的目标资源设备以及任务调度周期,由目标资源设备根据任务执行指令,启动与目标待执行任务相对应的任务线程,并对目标待执行任务进行处理。基于所述目标资源设备接收所述任务执行指令,并启动与所述目标待执行任务相对应的任务线程,用于基于目标资源设备中的任务线程以及目标待执行任务的任务调度周期,确定任务线程是否在任务调度周期内完成任务。基于所述任务线程和所述任务调度周期,确定所述目标待执行任务的处理结果,确定目标资源设备的任务状态,然后根据处理结果可以根据对任务线程进行释放操作,或者将新的执行任务发送给任务状态为空闲状态的资源设备。解决了当操作系统中的有多个执行任务需要被处理,可能会出现任务调度阻塞,进而导致对资源设备造成性能负载的问题,实现了对各资源设备进行合理的任务调度,解决任务调度阻塞并减轻资源设备性能负载的效果。
在本发明实施例中任一可选技术方案的基础上,可选地,所述指令发送模块,包括:
调度周期获取模块,用于从第一数据表中获取所述目标待执行任务的任务调度周期;其中,所述第一数据表中包括至少一个待执行任务和与各待执行任务相对应的任务调度周期;
目标资源设备获取模块,用于从第二数据表中获取与所述目标待执行任务相对应的目标资源设备;其中,所述第二数据表中包括执行节点和所述执行节点的任务状态;所述执行节点与资源设备相对应。
在本发明实施例中任一可选技术方案的基础上,可选地,所述目标资源设备获取模块,用于:
从所述第二数据表中获取所述任务状态为空闲状态的目标资源设备。
在本发明实施例中任一可选技术方案的基础上,可选地,所述任务线程启动模块,包括:
请求发送子模块,用于基于目标资源设备接收所述任务执行指令时,向目标系统发送线程建立请求;
任务线程创建子模块,用于基于所述目标系统接收所述线程建立请求,并创建与所述目标待执行任务相对应的任务线程。
在本发明实施例中任一可选技术方案的基础上,可选地,所述处理结果确定模块,包括:
持续时长确定子模块,用于基于目标监听函数,确定所述任务线程的持续时长;
处理结果确定子模块,用于若所述持续时长小于所述任务调度周期,则确定所述目标待执行任务的处理结果为完成任务。
在本发明实施例中任一可选技术方案的基础上,可选地,所述处理结果确定子模块,还用于:
若所述持续时长大于等于所述任务调度周期,则将所述任务线程释放,并确定所述目标待执行任务的处理结果为未完成任务,并向目标终端设备发送预警信息。
在本发明实施例中任一可选技术方案的基础上,可选地,所述处理结果确定子模块,还用于:
将所述目标资源设备在第二数据表中的任务状态从忙碌状态更新为空闲状态。
本发明实施例所提供的任务处理装置可执行本发明任意实施例所提供的任务处理方法,具备执行方法相应的功能模块和有益效果。
值得注意的是,上述装置所包括的各个单元和模块只是按照功能逻辑进行划分的,但并不局限于上述的划分,只要能够实现相应的功能即可;另外,各功能单元的具体名称也只是为了便于相互区分,并不用于限制本发明实施例的保护范围。
实施例五
图5为本发明实施例五提供的一种电子设备的结构示意图。图5示出了适于用来实现本发明实施例实施方式的示例性电子设备40的框图。图5显示的电子设备40仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图5所示,电子设备40以通用计算设备的形式表现。电子设备40的组件可以包括但不限于:一个或者多个处理器或者处理单元401,系统存储器402,连接不同系统组件(包括系统存储器402和处理单元401)的总线403。
总线403表示几类总线结构中的一种或多种,包括存储器总线或者存储器控制器,外围总线,图形加速端口,处理器或者使用多种总线结构中的任意总线结构的局域总线。举例来说,这些体系结构包括但不限于工业标准体系结构(ISA)总线,微通道体系结构(MAC)总线,增强型ISA总线、视频电子标准协会(VESA)局域总线以及外围组件互连(PCI)总线。
电子设备40典型地包括多种计算机系统可读介质。这些介质可以是任何能够被电子设备40访问的可用介质,包括易失性和非易失性介质,可移动的和不可移动的介质。
系统存储器402可以包括易失性存储器形式的计算机系统可读介质,例如随机存取存储器(RAM)404和/或高速缓存存储器405。电子设备40可以进一步包括其它可移动/不可移动的、易失性/非易失性计算机系统存储介质。仅作为举例,存储系统406可以用于读写不可移动的、非易失性磁介质(图5未显示,通常称为“硬盘驱动器”)。尽管图5中未示出,可以提供用于对可移动非易失性磁盘(例如“软盘”)读写的磁盘驱动器,以及对可移动非易失性光盘(例如CD-ROM,DVD-ROM或者其它光介质)读写的光盘驱动器。在这些情况下,每个驱动器可以通过一个或者多个数据介质接口与总线403相连。存储器402可以包括至少一个程序产品,该程序产品具有一组(例如至少一个)程序模块,这些程序模块被配置以执行本发明各实施例的功能。
具有一组(至少一个)程序模块407的程序/实用工具408,可以存储在例如存储器402中,这样的程序模块407包括但不限于操作系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。程序模块407通常执行本发明所描述的实施例中的功能和/或方法。
电子设备40也可以与一个或多个外部设备409(例如键盘、指向设备、显示器410等)通信,还可与一个或者多个使得用户能与该电子设备40交互的设备通信,和/或与使得该电子设备40能与一个或多个其它计算设备进行通信的任何设备(例如网卡,调制解调器等等)通信。这种通信可以通过输入/输出(I/O)接口411进行。并且,电子设备40还可以通过网络适配器412与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。如图所示,网络适配器412通过总线403与电子设备40的其它模块通信。应当明白,尽管图5中未示出,可以结合电子设备40使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、RAID系统、磁带驱动器以及数据备份存储系统等。
处理单元401通过运行存储在系统存储器402中的程序,从而执行各种功能应用以及数据处理,例如实现本发明实施例所提供的任务处理方法。
实施例六
本发明实施例六还提供一种包含计算机可执行指令的存储介质,所述计算机可执行指令在由计算机处理器执行时用于执行任务处理方法,该方法包括:
确定与目标待执行任务相对应的任务执行指令,并将所述任务执行指令发送至所述目标资源设备;其中,所述任务执行指令中包括执行所述目标待执行任务的目标资源设备以及任务调度周期;
基于所述目标资源设备接收所述任务执行指令,并启动与所述目标待执行任务相对应的任务线程;
基于所述任务线程和所述任务调度周期,确定所述目标待执行任务的处理结果。
本发明实施例的计算机存储介质,可以采用一个或多个计算机可读的介质的任意组合。计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本文件中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。
计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括——但不限于无线、电线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言或其组合来编写用于执行本发明实施例操作的计算机程序代码,所述程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言——诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
注意,上述仅为本发明的较佳实施例及所运用技术原理。本领域技术人员会理解,本发明不限于这里所述的特定实施例,对本领域技术人员来说能够进行各种明显的变化、重新调整和替代而不会脱离本发明的保护范围。因此,虽然通过以上实施例对本发明进行了较为详细的说明,但是本发明不仅仅限于以上实施例,在不脱离本发明构思的情况下,还可以包括更多其他等效实施例,而本发明的范围由所附的权利要求范围决定。
Claims (10)
1.一种任务处理方法,其特征在于,包括:
确定与目标待执行任务相对应的任务执行指令,并将所述任务执行指令发送至所述目标资源设备;其中,所述任务执行指令中包括执行所述目标待执行任务的目标资源设备以及任务调度周期;
基于所述目标资源设备接收所述任务执行指令,并启动与所述目标待执行任务相对应的任务线程;
基于所述任务线程和所述任务调度周期,确定所述目标待执行任务的处理结果。
2.根据权利要求1所述的方法,其特征在于,所述确定与目标待执行任务相对应的任务执行指令,并将所述任务执行指令发送至所述目标资源设备,包括:
从第一数据表中获取所述目标待执行任务的任务调度周期;其中,所述第一数据表中包括至少一个待执行任务和与各待执行任务相对应的任务调度周期;
从第二数据表中获取与所述目标待执行任务相对应的目标资源设备;其中,所述第二数据表中包括执行节点和所述执行节点的任务状态;所述执行节点与资源设备相对应。
3.根据权利要求2所述的方法,其特征在于,所述任务状态包括空闲状态和忙碌状态,所述从第二数据表中获取与所述目标待执行任务相对应的目标资源设备,包括:
从所述第二数据表中获取所述任务状态为空闲状态的目标资源设备。
4.根据权利要求1所述的方法,其特征在于,所述基于所述目标资源设备接收所述任务执行指令,并启动与所述目标待执行任务相对应的任务线程,包括:
基于目标资源设备接收所述任务执行指令时,向目标系统发送线程建立请求;
基于所述目标系统接收所述线程建立请求,并创建与所述目标待执行任务相对应的任务线程。
5.根据权利要求1所述的方法,其特征在于,所述基于所述任务线程和所述任务调度周期,确定所述目标待执行任务的处理结果,包括:
基于目标监听函数,确定所述任务线程的持续时长;
若所述持续时长小于所述任务调度周期,则确定所述目标待执行任务的处理结果为完成任务。
6.根据权利要求5所述的方法,其特征在于,还包括:
若所述持续时长大于等于所述任务调度周期,则将所述任务线程释放,并确定所述目标待执行任务的处理结果为未完成任务,并向目标终端设备发送预警信息。
7.根据权利要求5或6所述的方法,其特征在于,还包括:
将所述目标资源设备在第二数据表中的任务状态从忙碌状态更新为空闲状态。
8.一种任务处理装置,其特征在于,包括:
指令发送模块,用于确定与目标待执行任务相对应的任务执行指令,并将所述任务执行指令发送至所述目标资源设备;其中,所述任务执行指令中包括执行所述目标待执行任务的目标资源设备以及任务调度周期;
任务线程启动模块,用于基于所述目标资源设备接收所述任务执行指令,并启动与所述目标待执行任务相对应的任务线程;
处理结果确定模块,用于基于所述任务线程和所述任务调度周期,确定所述目标待执行任务的处理结果。
9.一种电子设备,其特征在于,所述电子设备包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-7中任一所述的任务处理方法。
10.一种包含计算机可执行指令的存储介质,其特征在于,所述计算机可执行指令在由计算机处理器执行时用于执行如权利要求1-7中任一所述的任务处理方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111497221.0A CN114168290A (zh) | 2021-12-09 | 2021-12-09 | 一种任务处理方法、装置、电子设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111497221.0A CN114168290A (zh) | 2021-12-09 | 2021-12-09 | 一种任务处理方法、装置、电子设备及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN114168290A true CN114168290A (zh) | 2022-03-11 |
Family
ID=80484737
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202111497221.0A Pending CN114168290A (zh) | 2021-12-09 | 2021-12-09 | 一种任务处理方法、装置、电子设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114168290A (zh) |
-
2021
- 2021-12-09 CN CN202111497221.0A patent/CN114168290A/zh active Pending
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP3799390B1 (en) | Preemptive scheduling based resource sharing use method, system and | |
KR100509794B1 (ko) | 데이터베이스 관리시스템을 이용하는 작업들의 실시간 처리를 위한 스케줄링 방법 | |
CN107241281B (zh) | 一种数据处理方法及其装置 | |
CN111078396B (zh) | 一种基于多任务实例的分布式数据接入方法和系统 | |
CN112486648A (zh) | 任务调度方法、装置、系统、电子设备和存储介质 | |
CN109840142B (zh) | 基于云监控的线程控制方法、装置、电子设备及存储介质 | |
CN111930525B (zh) | Gpu资源使用方法、电子设备及计算机可读介质 | |
CN106557369A (zh) | 一种多线程的管理方法及系统 | |
CN109766172B (zh) | 一种异步任务调度方法以及装置 | |
EP4361808A1 (en) | Resource scheduling method and device and computing node | |
CN111708625A (zh) | 多用户任务执行方法、装置、设备及存储介质 | |
CN102420709A (zh) | 一种基于任务框架的调度任务管理方法和设备 | |
CN111679911A (zh) | 云环境中gpu卡的管理方法、装置、设备及介质 | |
CN101424941A (zh) | 一种控制实现方法和系统 | |
CN113658351B (zh) | 一种产品生产的方法、装置、电子设备及存储介质 | |
CN111522630B (zh) | 基于批次调度中心的计划任务执行方法以及系统 | |
CN106843890B (zh) | 基于智能决策的传感器网络、节点及其运行方法 | |
US12019909B2 (en) | IO request pipeline processing device, method and system, and storage medium | |
CN114168290A (zh) | 一种任务处理方法、装置、电子设备及存储介质 | |
CN113391896B (zh) | 任务处理方法及装置、存储介质及电子设备 | |
CN117093335A (zh) | 分布式存储系统的任务调度方法及装置 | |
CN114675954A (zh) | 任务调度方法及装置 | |
CN114691376A (zh) | 一种线程执行方法、装置、电子设备和存储介质 | |
CN114253686A (zh) | 一种任务调度方法、装置、电子设备及存储介质 | |
CN113888028A (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 |