CN111026530A - 一种任务调度方法、装置、计算机设备和存储介质 - Google Patents

一种任务调度方法、装置、计算机设备和存储介质 Download PDF

Info

Publication number
CN111026530A
CN111026530A CN201911207006.5A CN201911207006A CN111026530A CN 111026530 A CN111026530 A CN 111026530A CN 201911207006 A CN201911207006 A CN 201911207006A CN 111026530 A CN111026530 A CN 111026530A
Authority
CN
China
Prior art keywords
task
scheduling
script
target
executing
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
Application number
CN201911207006.5A
Other languages
English (en)
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.)
Zhuhai Suibian Technology Co ltd
Original Assignee
Zhuhai Suibian 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 Zhuhai Suibian Technology Co ltd filed Critical Zhuhai Suibian Technology Co ltd
Priority to CN201911207006.5A priority Critical patent/CN111026530A/zh
Publication of CN111026530A publication Critical patent/CN111026530A/zh
Pending legal-status Critical Current

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/48Program initiating; Program switching, e.g. by interrupt
    • G06F9/4806Task transfer initiation or dispatching
    • G06F9/4843Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
    • G06F9/4881Scheduling strategies for dispatcher, e.g. round robin, multi-level priority queues
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/24Querying
    • G06F16/245Query processing
    • G06F16/2455Query execution

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computational Linguistics (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Stored Programmes (AREA)

Abstract

本发明公开了一种任务调度方法、装置、计算机设备和存储介质。该方法包括:获取与第一任务对应的任务脚本;在所述任务脚本中解析任务配置指令,并根据所述任务配置指令确定第一任务类型;根据与所述第一任务类型匹配的任务处理策略,以及所述任务脚本,执行所述第一任务,并对所述第一任务的执行结果在人机交互界面中进行展示。使用本发明的技术方案,可以实现任务调度的高扩展性和高灵活性,并且能够直观的展示任务状态。

Description

一种任务调度方法、装置、计算机设备和存储介质
技术领域
本发明实施例涉及计算机应用技术领域,尤其涉及一种任务调度方法、装置、计算机设备和存储介质。
背景技术
随着公司业务的发展,数据仓库、数据服务以及BI(Business Intelligence,商务智能)等系统对任务处理的需求也越来越高。
现有技术中,一般采用Linux Crontab命令配置任务调度。Crontab命令需要crond进程支持,crond是Linux下用来周期性的执行某种任务或等待处理某些事件的一个守护进程,crond进程每分钟会定期检查是否有要执行的任务,如果有要执行的任务,则自动执行该任务。
发明人在实现本发明的过程中,发现现有技术存在以下缺陷:使用Linux Crontab命令配置任务时,需要开发人员熟悉Linux代码,对开发人员要求高,且任务配置过程复杂;同时,任务进度不可控,且任务状态不可见;并且使用Linux Crontab命令配置任务的可扩展性和灵活性较差,无法满足用户的实际需求。
发明内容
本发明实施例提供一种任务调度方法、装置、计算机设备和存储介质,以实现任务调度的高扩展性和高灵活性,能够直观的展示任务状态。
第一方面,本发明实施例提供了一种任务调度方法,该方法包括:
获取与第一任务对应的任务脚本;
在所述任务脚本中解析任务配置指令,并根据所述任务配置指令确定第一任务类型;
根据与所述第一任务类型匹配的任务处理策略,以及所述任务脚本,执行所述第一任务,并对所述第一任务的执行结果在人机交互界面中进行展示。
第二方面,本发明实施例还提供了一种任务调度装置,该装置包括:
任务脚本获取模块,用于获取与第一任务对应的任务脚本;
第一任务类型确定模块,用于在所述任务脚本中解析任务配置指令,并根据所述任务配置指令确定第一任务类型;
第一任务执行模块,用于根据与所述第一任务类型匹配的任务处理策略,以及所述任务脚本,执行所述第一任务,并对所述第一任务的执行结果在人机交互界面中进行展示。
第三方面,本发明实施例还提供了一种计算机设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,所述处理器执行所述程序时实现如本发明实施例中任一所述的任务调度方法。
第四方面,本发明实施例还提供了一种包含计算机可执行指令的存储介质,所述计算机可执行指令在由计算机处理器执行时用于执行如本发明实施例中任一所述的任务调度方法。
本发明实施例的技术方案通过获取任务脚本,并根据任务脚本获取任务配置指令,通过解析任务配置指令确定任务类型,针对不同的任务类型采用不同的任务处理策略执行任务,并将执行结果展示到人机交互界面。解决了现有技术无法可视化的查看任务是否成功执行,以及可扩展性较差的问题,实现了随时查看任务状态的效果,并通过执行任务的脚本化,提高了任务调度的可扩展性和灵活性。
附图说明
图1是本发明实施例一中的一种任务调度方法的流程图;
图2是本发明实施例二中的一种任务调度方法的流程图;
图3是适用于本发明实施例中的实现数据源组件调用任务的流程图;
图4是本发明实施例三中的一种任务调度方法的流程图;
图5是本发明实施例四中的一种任务调度装置的结构示意图;
图6是本发明实施例五中的一种计算机设备的结构示意图。
具体实施方式
下面结合附图和实施例对本发明作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释本发明,而非对本发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与本发明相关的部分而非全部结构。
实施例一
图1是本发明实施例一提供的一种任务调度方法的流程图,本实施例可适用于服务器针对预先设定的任务进行调度执行的情况,该方法可以由任务调度装置来执行,该装置可以由软件和/或硬件来实现,并一般可以集成在服务器中。
如图1所示,本发明实施例的技术方案,具体包括如下步骤:
S110、获取与第一任务对应的任务脚本。
其中,第一任务可以是一个需要被执行的任务,在一个具体的例子中,第一任务可以是发送数据邮件,批量导入数据,查看商品复购率数据等任务,本实施例对第一任务的类型和具体内容不进行限制。
任务脚本是与第一任务所对应的脚本,脚本通常以文本的形式进行保存,只在被调用时进行解释或编译。
在本发明一个可选的实施例中,在获取与第一任务对应的任务脚本之前,还可以包括:响应于用户在所述人机交互界面中输入的任务配置信息,生成所述第一任务。
其中,任务配置信息可以为用户自定义的,用于生成第一任务的相关信息,可以包括任务执行方式、执行周期、执行时间以及执行对象等。用户可以在人际交互界面输入任务配置信息,响应于该任务配置信息,生成与该任务配置信息对应的第一任务。在一个具体的示例中,当用户需要查看商品复购率数据时,任务配置信息可以为每天上午七点自动执行,获取商品复购率数据。这样设置的好处在于,实现了配置任务的可视化,简化了配置任务的操作流程,提高了用户的使用体验。
在本发明一个可选的实施例中,在响应于用户在所述人机交互界面中输入的任务配置信息,生成所述第一任务之后,还可以包括:创建第一调度工作模块,并通过所述第一调度工作模块执行针对所述第一任务的任务调度方法。响应于用户在所述人机交互界面中输入的任务配置信息,生成第二任务;创建第二调度工作模块,并通过所述第二调度工作模块执行针对所述第二任务的任务调度方法。
其中,调度工作模块是任务调度方法的执行主体,任务通过调度工作模块执行。第一调度工作模块针对第一任务执行任务调度方法,第二调度工作模块针对第二任务执行任务调度方法。这样设置的好处在于,可以实现对不同任务的单独管理,对单个任务进行修改,不会对其他已有的任务产生影响。
S120、在所述任务脚本中解析任务配置指令,并根据所述任务配置指令确定第一任务类型。
其中,任务配置指令可以为指示完成某项任务的指令或与配置任务信息相关的指令,在一个具体的示例中,任务配置指令可以为日期指令、任务参数指令、批量导入数据指令以及发送数据邮件指令等。任务类型可以包括数据源组件调用任务类型,或者目标业务接口调用任务类型。数据源组件调用任务为需要从数据源中获取数据的任务,目标业务接口调用任务为需要调用其它业务接口的任务。
在一个具体的示例中,查看商品复购率数据任务需要从数据源中获取商品复购率数据,为一个数据源组件调用任务,而用户消费失败时,需要进行的消费补偿任务,需要调用补偿接口,则消费补偿任务为一个目标业务接口调用任务。在本发明实施例中,在任务脚本中解析任务配置指令,可以对任务参数进行配置,以及区分任务类型。
S130、根据与所述第一任务类型匹配的任务处理策略,以及所述任务脚本,执行所述第一任务,并对所述第一任务的执行结果在人机交互界面中进行展示。
其中,任务处理策略可以为对任务进行处理或执行的策略,不同类型的任务可以对应不同的任务处理策略。在本发明实施例中,根据任务配置指令确定任务类型后,可以根据任务类型采取对应的任务处理策略,根据任务处理策略和任务脚本执行第一任务。执行结果可以包括执行成功或执行失败,执行完毕后,将执行结果在人机交互界面上进行展示。在一个具体的示例中,可以实时的将执行结果展示到人际交互界面。
在另一个具体的示例中,也可以先将执行结果进行保存,每隔预设时间对人际交互界面进行刷新,展示预设时间内保存的执行结果。本发明实施例对在人际交互界面展示执行结果的方式不进行限制。这样设置的好处在于,可以实时显示任务的最新情况,直观的向用户展示任务状态。
本实施例的技术方案,通过获取任务脚本,并根据任务脚本获取任务配置指令,通过解析任务配置指令确定任务类型,针对不同的任务类型采用不同的任务处理策略执行任务,并将执行结果展示到人机交互界面。解决了现有技术无法可视化的查看任务是否成功执行,以及可扩展性较差的问题,实现了随时查看任务状态的效果,并通过执行任务的脚本化,提高了任务调度的可扩展性和灵活性。
实施例二
图2是本发明实施例二提供的一种任务调度方法的流程图,本发明实施例在上述实施例的基础上,对根据与任务类型匹配的任务处理策略和任务脚本执行任务的具体步骤进行了进一步的具体化。
相应的,如图2所示,本发明实施例的技术方案,具体包括如下步骤:
S210、响应于用户在所述人机交互界面中输入的任务配置信息,生成第一任务。
S220、创建第一调度工作模块,并通过所述第一调度工作模块执行针对所述第一任务的任务调度方法。
S230、判断是否检测到与所述第一任务对应的定时执行指令,如果是,则执行S240,否则,执行S2180。
其中,定时执行指令可以为定时自动执行任务所对应的指令。定时自动执行任务无需人工处理,可以按照配置定时自动执行。在一个具体的示例中,在一个具体的示例中,每天上午七点自动获取商品复购率数据的任务就是一个定时自动任务,任务配置好之后,每天上午七点自动执行。这样设置的好处在于,可以提高任务的执行效率,降低人工成本。
S240、判断是否确定存在空闲调度,如果是,则执行S250,否则,执行S260。
其中,调度可以使用相关的调度算法来决定当前需要执行的任务。空闲调度可以是一个处于就绪态的调度,可以通过启动该空闲调度,将该空闲调度的状态变更为运行态。在本发明实施例中,要启动一个调度,可以先判断是否存在空闲调度,如果存在空闲调度,可以直接启动该空闲调度。
S250、将与所述空闲调度连接的任务变更为所述第一任务,并将所述空闲调度作为目标调度。
在本发明实施例中,每个调度都可以与一个任务进行连接,并配置任务的执行周期,然后将任务加载到调度中,再启动该调度。任务执行完毕后,该已执行完毕的任务不会与调度进行解除连接。因此当存在空闲调度时,可以先将与该空闲调度连接的已执行完毕的任务,变更为所要执行的第一任务。
S260、创建新调度,将所述新调度与所述第一任务进行连接,并将所述新调度作为目标调度。
在本发明实施例中,如果不存在一个空闲调度,可以创建一个新调度,并将该新调度与本次要执行的第一任务进行连接。
S270、启动所述目标调度,并通过所述目标调度,获取与所述第一任务对应的任务脚本。
其中,目标调度为要执行第一任务需要使用的调度。在本发明实施例中,如果存在空闲调度,则将空闲调度作为目标调度,否则就创建一个新调度作为目标调度。并通过目标调度,获取第一任务的任务脚本。
在一个具体的示例中,启动目标调度,获取任务脚本,可以通过调度引擎来完成。其中,调度引擎可以提供对调度的设置、管理和执行功能。
在另一个具体的示例中,可以选用Quartz作为框架,Quartz是一个完全由java编写的开源作业调度框架,为在Java应用程序中进行作业调度提供了简单却强大的机制。Quartz的调度引擎包括四个核心组件:工作、任务、触发器以及调度,工作可以指要执行的具体内容,任务可以指一个具体的可执行的任务,还可以包含任务调度的方案和策略,触发器可以进行调度参数的配置。当调度与任务进行连接后,配置任务执行周期,将任务加载到调度中,启动调度,Quartz调度引擎就可以自动按照配置的任务执行周期执行调度。在又一具体实施例中,可以选用Jcrontab、Fulcrum以及JobScheduler等框架作为执行定时自动任务的框架,本发明实施例对执行定时自动任务的框架类型并不进行限制。
S280、在所述任务脚本中解析任务配置指令,并根据所述任务配置指令确定第一任务类型。
S290、判断所述第一任务类型是否为数据源组件调用任务,如果是,则执行S2100,否则执行S2130。
在本发明实施例中,如果第一任务类型为数据源组件调用任务,则可以选用与数据源组件调用任务相匹配的任务处理策略,结合第一任务的任务脚本,执行该第一任务。
S2100、在所述任务脚本中解析查询语句,并在所述任务脚本中获取目标数据源类型。
其中,查询语句可以由脚本中的原始查询语句与配置的参数拼装得来,查询语句的作用在于表明第一任务所需数据的类型。在一个具体的示例中,每天上午七点自动获取商品复购率数据的任务中,查询语句与本次任务所要获取的商品复购率数据所对应。目标数据源类型可以表明本次任务所需数据所在具体数据源的类型,目标数据源类型可以包括hive数据源、impala数据源以及mysql数据源等。不同的任务可以从不同的数据源中获取数据,在一个具体的示例中,统计运营指标任务需要快速统计大量数据,可以使用impala数据源。在另一个具体的示例中,统计商品复购率数据任务需要对商品复购率数据进行统计,但是对统计时长要求不高,可以使用hive数据源。在又一具体示例中,统计商品差评信息并向商家发送邮件提醒任务,需要统计的商品差评数据量较小,可以使用mysql数据源。
在一个具体的示例中,可以在脚本中配置多种类型的数据源,在调度工作模块启动时,将配置的数据源全部加载到缓存中。这样设置的好处在于,执行任务时,可以根据任务的实际需要,对数据源进行灵活调用,实现了数据源的自动管理,满足了用户根据实际情况选择数据源的需要。
S2110、将所述查询语句和目标数据源类型发送至指向数据源集合的目标接口,以通过所述目标接口建立与所述目标数据源的连接,并向所述目标数据源发送所述查询语句。
其中,目标接口的作用可以是建立调度工作模块与目标数据源之间的连接,并将查询语句发送给目标数据源。在一个具体的示例中,目标接口可以是Statement,Statement是Java执行数据库操作的一个重要接口,用于在已经建立数据库连接的基础上,向数据库发送要执行的查询语句。在本发明实施例中,查询语句拼装完毕后,首先提交给目标接口,目标接口根据目标数据源类型,以及查询语句,查询是否存在目标数据源,如果存在,就建立调度工作模块与目标数据源之间的连接,并将查询语句发送给目标数据源。
在一个具体的示例中,S280-S2110中,解析任务配置指令,确定第一任务类型,获取目标数据源类型,以及发送查询语句都可以由脚本引擎执行。脚本引擎的功能是可以解释执行用户的程序文本,将它翻译成计算机能执行的机器代码,完成一系列的功能。
在又一具体的示例中,可以在调度引擎启动调度后,调用脚本引擎。
S2120、获取与所述查询语句对应的目标数据,根据所述目标数据执行所述第一任务。
其中,目标数据可以为执行第一任务所需要的数据,在一个具体的示例中,每天上午七点自动获取商品复购率数据的任务中,目标数据为商品复购率数据。
在一个具体的示例中,获取目标数据之后,可以将当前调度工作模块与目标数据源之间的连接断开,以供其他调度工作模块使用。
在本发明实施例中,执行完毕所述第一任务之后,将执行结果在人机交互界面进行展示。
S2130、判断所述第一任务类型是否为目标业务接口调用任务,如果是,则执行S2140,否则,执行S2180。
在本发明实施例中,如果第一任务类型不是数据源组件调用任务,则判断所述第一任务类型是否为目标业务接口调用任务,如果是,则可以选用与目标业务接口调用任务相匹配的任务处理策略,结合第一任务的任务脚本,执行该第一任务。
S2140、在所述第一任务脚本中获取设定跳转指令,并根据所述跳转指令构造请求发送至任务公共域。
其中,跳转指令可以为一个指示由当前脚本跳转至其他位置执行特定流程的指令,请求可以为需要调用其它业务接口的请求。在一个具体的示例中,请求可以为HTTP(Hypertext Transfer Protocol,超文本传输协议)请求。任务公共域可以为一个中间层系统,可以通过集成API(Application Programming Interface,应用程序接口)为用户提供多种业务接口。
在本发明实施例中,在任务脚本中解析跳转指令,并根据该跳转指令拼装请求,将该请求发送至任务公共域。
在一个具体的示例中,获取跳转指令,根据跳转指令构造请求,以及发送请求可以由脚本引擎来执行。
S2150、接收所述任务公共域针对所述请求反馈的至少一个目标业务接口。
其中,目标业务接口为执行第一任务时所需调用的业务接口。在本发明实施例中,任务公共域接收到调度工作模块发送的请求后,查看是否存在与该请求对应的目标业务接口,如果存在,则将该目标业务接口反馈给调度工作模块。
S2160、调用目标业务接口,执行所述第一任务。
在一个具体的示例中,用户消费失败时,需要进行的消费补偿任务,向任务公共域发送请求后,任务公共域向调度工作模块反馈补偿接口,调度工作模块通过调用该反馈补偿接口执行消费补偿任务。
S2170、对所述第一任务的执行结果在人机交互界面中进行展示。
S2180、结束。
在本发明一个可选的实施例中,图3是适用于本发明实施例中的实现数据源组件调用任务的流程图,图3中适用Quartz作为定时任务框架。如图3所示,用户可以在Web管理模块实现对任务、调度以及数据源的管理,Web管理模块包括任务配置管理模块、调度配置管理模块以及数据源管理模块。任务配置管理模块可以实现对任务的新增、修改、删除、查询、立即执行以及新增任务时保存脚本文件等功能。调度配置管理模块可以实现对调度的新增、关联、删除、查询、启动以及停止功能。数据源管理模块可以实现对数据源的新增、修改、删除、查看、启用以及停用功能。
当用户选择立即执行任务功能时,可以无需启动调度,直接调用脚本引擎。当用户选择启动调度功能时,调度工作模块首先判断是否存在空闲调度,如果存在,则调用Quartz接口修改调度任务并启动调度,否则调用Quartz接口创建调度任务并启动调度。启动调度之后,调度引擎调用脚本引擎,由脚本引擎进行解析指令、解析脚本、获取脚本中对应的数据源类型以及提交查询语句,并调用相应的数据源,将执行结果返回给任务管理模块展示给用户。
当新增任务时,使用不同的调度工作模块执行该新增任务,保证对不同任务可以单独进行管理。当用户选择删除调度时,调用Quartz接口移除该调度,当用户选择停止调度时,调用Quartz接口暂停该调度。Web管理模块还可以实现对数据源的管理,当用户选择启用数据源时,调度工作模块调用相应的组件配置相应的数据源,当用户选择停用数据源时,将该数据源的连接关闭。在对任务的新增、修改、删除、查询、立即执行以及新增任务时保存脚本文件时,对调度的新增、关联、删除、查询、启动以及停止时,对数据源的新增、修改、删除、查看、启用时,以及调度引擎在启动调度时,都会与数据库之间进行交互。
本实施例的技术方案,通过调度工作模块执行任务调度,当任务为定时任务时,获取并启动目标调度,通过目标调度获取任务脚本,根据任务脚本获取任务配置指令,当根据任务配置指令判断任务类型为数据源组件调用任务时,在任务脚本中解析查询语句,获取目标数据源类型,再由接口根据查询语句和目标数据源类型与目标数据源建立连接,获取目标数据,根据目标数据执行任务,将任务执行结果反馈给用户。解决了现有技术配置任务时操作复杂,每次配置任务都需要修改文件,风险性较高,并且无法获取任务执行状态的问题。实现了任务配置的脚本化,增强了任务配置的可扩展性和灵活性,实现了任务和调度配置的可视化,操作流程更为简单,可以及时监控任务状态,提高了用户体验。
实施例三
图4是本发明实施例三提供的一种任务调度方法的流程图,本发明实施例在上述实施例的基础上,对根据与任务类型匹配的任务处理策略和任务脚本执行任务的具体步骤进行了进一步的具体化。
相应的,如图4所示,本发明实施例的技术方案,具体包括如下步骤:
S310、响应于用户在所述人机交互界面中输入的任务配置信息,生成所述第一任务。
S320、创建第一调度工作模块,并通过所述第一调度工作模块执行针对所述第一任务的任务调度方法。
S330、判断是否检测到与所述第一任务对应的立即执行指令,如果是,执行S340,否则,执行S3150。
其中,立即执行指令可以为用户手动立即执行任务所对应的指令,用户手动立即执行任务可以为需要用户手动触发执行,并且需要立即执行的任务。在本发明实施例中,用户可以通过人机交互界面发出立即执行指令,调度工作模块接收到立即执行指令后,立即触发任务执行。在一个具体的示例中,任务执行异常时重新执行任务可以为一个用户手动立即执行任务,可以由用户通过人机交互界面发出立即执行指令。立即执行指令还可以为用户手动立即执行批量任务所对应的指令,用户手动立即执行批量任务可以为对用户手动立即执行任务的批量操作。
S340、获取与所述第一任务对应的任务脚本。
当调度工作模块接收到的是立即执行指令时,可以无需启动调度,直接获取任务脚本。获取任务脚本后的操作,与调度工作模块接收到的是定时执行指令时的操作相同,在此不再赘述。
S350、在所述任务脚本中解析任务配置指令,并根据所述任务配置指令确定第一任务类型。
S360、判断所述第一任务类型是否为数据源组件调用任务,如果是,则执行S370,否则执行S3100。
S370、在所述任务脚本中解析查询语句,并在所述任务脚本中获取目标数据源类型。
S380、将所述查询语句和目标数据源类型发送至指向数据源集合的目标接口,以通过所述目标接口建立与所述目标数据源的连接,并向所述目标数据源发送所述查询语句。
S390、获取与所述查询语句对应的目标数据,根据所述目标数据执行所述第一任务。
S3100、判断所述第一任务类型是否为目标业务接口调用任务,如果是,则执行S3110,否则执行S3150。
S3110、在所述第一任务脚本中获取设定跳转指令,并根据所述跳转指令构造请求发送至任务公共域。
S3120、接收所述任务公共域针对所述请求反馈的至少一个目标业务接口。
S3130、调用目标业务接口,执行所述第一任务。
S3140、对所述第一任务的执行结果在人机交互界面中进行展示。
S3150、结束。
本实施例的技术方案,通过调度工作模块执行任务调度,当任务为立即执行时,获取任务脚本,根据任务脚本获取任务配置指令,当根据任务配置指令判断任务类型为数据源组件调用任务时,在任务脚本中解析查询语句,获取目标数据源类型,再由接口根据查询语句和目标数据源类型与目标数据源建立连接,获取目标数据,根据目标数据执行任务,将任务执行结果反馈给用户。解决了现有技术配置任务时操作复杂,每次配置任务都需要修改文件,风险性较高,并且无法获取任务执行状态的问题。实现了任务配置的脚本化,增强了任务配置的可扩展性和灵活性,实现了任务和调度配置的可视化,操作流程更为简单,可以及时监控任务状态,通过设置不同的执行方式,可以满足用户在不同情况下的实际需求,提高了用户体验。
实施例四
图5是本发明实施例四提供的一种任务调度装置的结构示意图,所述任务调度装置包括:任务脚本获取模块410、第一任务类型确定模块420以及第一任务执行模块430,其中:
任务脚本获取模块410,用于获取与第一任务对应的任务脚本;
第一任务类型确定模块420,用于在所述任务脚本中解析任务配置指令,并根据所述任务配置指令确定第一任务类型;
第一任务执行模块430,用于根据与所述第一任务类型匹配的任务处理策略,以及所述任务脚本,执行所述第一任务,并对所述第一任务的执行结果在人机交互界面中进行展示。
本发明实施例的技术方案通过获取任务脚本,并根据任务脚本获取任务配置指令,通过解析任务配置指令确定任务类型,针对不同的任务类型采用不同的任务处理策略执行任务,并将执行结果展示到人机交互界面。解决了现有技术无法可视化的查看任务是否成功执行,以及可扩展性较差的问题,实现了随时查看任务状态的效果,并通过执行任务的脚本化,提高了任务调度的可扩展性和灵活性。
在上述实施例的基础上,所述装置,还包括:
第一任务生成模块,用于响应于用户在所述人机交互界面中输入的任务配置信息,生成所述第一任务。
在上述实施例的基础上,所述第一任务执行模块430,包括:
目标数据源类型获取单元,用于如果所述第一任务类型为数据源组件调用任务,则在所述任务脚本中解析查询语句,并在所述任务脚本中获取目标数据源类型;
查询语句发送单元,用于将所述查询语句和目标数据源类型发送至指向数据源集合的目标接口,以通过所述目标接口建立与所述目标数据源的连接,并向所述目标数据源发送所述查询语句;
目标数据获取单元,获取与所述查询语句对应的目标数据,根据所述目标数据执行所述第一任务。
在上述实施例的基础上,所述第一任务执行模块430,还包括:
请求发送单元,用于如果所述第一任务类型为目标业务接口调用任务,则在所述第一任务脚本中获取设定跳转指令,并根据所述跳转指令构造请求发送至任务公共域;
目标业务接口接收单元,用于接收所述任务公共域针对所述请求反馈的至少一个目标业务接口;
目标业务接口调用单元,用于调用目标业务接口,执行所述第一任务。
在上述实施例的基础上,所述任务脚本获取模块410,包括:
第一任务脚本获取单元,用于在检测到与所述第一任务对应的立即执行指令时,获取与所述第一任务对应的任务脚本。
在上述实施例的基础上,所述任务脚本获取模块410,还包括:
目标调度获取单元,用于在检测到与所述第一任务对应的定时执行指令时,获取目标调度;
第二任务脚本获取单元,用于启动所述目标调度,并通过所述目标调度,获取与所述第一任务对应的任务脚本。
在上述实施例的基础上,所述目标调度获取单元,包括:
第一目标调度获取子单元,用于如果确定存在空闲调度,则将与所述空闲调度连接的任务变更为所述第一任务,并将所述空闲调度作为目标调度;
第二目标调度获取子单元,用于如果确定不存在空闲调度,则创建新调度,将所述新调度与所述第一任务进行连接,并将所述新调度作为目标调度。
在上述实施例的基础上,所述装置,还包括:
第一调度工作模块创建模块,用于创建第一调度工作模块,并通过所述第一调度工作模块执行针对所述第一任务的任务调度方法;
第二任务生成模块,用于响应于用户在所述人机交互界面中输入的任务配置信息,生成第二任务;
第二调度工作模块创建模块,用于创建第二调度工作模块,并通过所述第二调度工作模块执行针对所述第二任务的任务调度方法。
本发明实施例所提供的任务调度装置可执行本发明任意实施例所提供的任务调度方法,具备执行方法相应的功能模块和有益效果。
实施例五
图6为本发明实施例五提供的一种计算机设备的结构示意图,如图6所示,该计算机设备包括处理器70、存储器71、输入装置72和输出装置73;计算机设备中处理器70的数量可以是一个或多个,图6中以一个处理器70为例;计算机设备中的处理器70、存储器71、输入装置72和输出装置73可以通过总线或其他方式连接,图6中以通过总线连接为例。
存储器71作为一种计算机可读存储介质,可用于存储软件程序、计算机可执行程序以及模块,如本发明实施例中的任务调度方法对应的模块(例如,任务调度装置中的任务脚本获取模块410、第一任务类型确定模块420以及第一任务执行模块430)。处理器70通过运行存储在存储器71中的软件程序、指令以及模块,从而执行计算机设备的各种功能应用以及数据处理,即实现上述的任务调度方法。
存储器71可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序;存储数据区可存储根据终端的使用所创建的数据等。此外,存储器71可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他非易失性固态存储器件。在一些实例中,存储器71可进一步包括相对于处理器70远程设置的存储器,这些远程存储器可以通过网络连接至计算机设备。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。
输入装置72可用于接收输入的数字或字符信息,以及产生与计算机设备的用户设置以及功能控制有关的键信号输入。输出装置73可包括显示屏等显示设备。
实施例六
本发明实施例六还提供一种包含计算机可执行指令的存储介质,所述计算机可执行指令在由计算机处理器执行时用于执行一种任务调度方法,该方法包括:
获取与第一任务对应的任务脚本;
在所述任务脚本中解析任务配置指令,并根据所述任务配置指令确定第一任务类型;
根据与所述第一任务类型匹配的任务处理策略,以及所述任务脚本,执行所述第一任务,并对所述第一任务的执行结果在人机交互界面中进行展示。
当然,本发明实施例所提供的一种包含计算机可执行指令的存储介质,其计算机可执行指令不限于如上所述的方法操作,还可以执行本发明任意实施例所提供的任务调度方法中的相关操作。
通过以上关于实施方式的描述,所属领域的技术人员可以清楚地了解到,本发明可借助软件及必需的通用硬件来实现,当然也可以通过硬件实现,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品可以存储在计算机可读存储介质中,如计算机的软盘、只读存储器(Read-Only Memory,ROM)、随机存取存储器(RandomAccess Memory,RAM)、闪存(FLASH)、硬盘或光盘等,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述的方法。
值得注意的是,上述任务调度装置的实施例中,所包括的各个单元和模块只是按照功能逻辑进行划分的,但并不局限于上述的划分,只要能够实现相应的功能即可;另外,各功能单元的具体名称也只是为了便于相互区分,并不用于限制本发明的保护范围。
注意,上述仅为本发明的较佳实施例及所运用技术原理。本领域技术人员会理解,本发明不限于这里所述的特定实施例,对本领域技术人员来说能够进行各种明显的变化、重新调整和替代而不会脱离本发明的保护范围。因此,虽然通过以上实施例对本发明进行了较为详细的说明,但是本发明不仅仅限于以上实施例,在不脱离本发明构思的情况下,还可以包括更多其他等效实施例,而本发明的范围由所附的权利要求范围决定。

Claims (11)

1.一种任务调度方法,其特征在于,包括:
获取与第一任务对应的任务脚本;
在所述任务脚本中解析任务配置指令,并根据所述任务配置指令确定第一任务类型;
根据与所述第一任务类型匹配的任务处理策略,以及所述任务脚本,执行所述第一任务,并对所述第一任务的执行结果在人机交互界面中进行展示。
2.根据权利要求1所述的方法,其特征在于,在获取与第一任务对应的任务脚本之前,还包括:
响应于用户在所述人机交互界面中输入的任务配置信息,生成所述第一任务。
3.根据权利要求1所述的方法,其特征在于,根据与所述第一任务类型匹配的任务处理策略,以及所述任务脚本,执行所述第一任务,包括:
如果所述第一任务类型为数据源组件调用任务,则在所述任务脚本中解析查询语句,并在所述任务脚本中获取目标数据源类型;
将所述查询语句和目标数据源类型发送至指向数据源集合的目标接口,以通过所述目标接口建立与所述目标数据源的连接,并向所述目标数据源发送所述查询语句;
获取与所述查询语句对应的目标数据,根据所述目标数据执行所述第一任务。
4.根据权利要求1所述的方法,其特征在于,根据与所述第一任务类型匹配的任务处理策略,以及所述任务脚本,执行所述第一任务,还包括:
如果所述第一任务类型为目标业务接口调用任务,则在所述第一任务脚本中获取设定跳转指令,并根据所述跳转指令构造请求发送至任务公共域;
接收所述任务公共域针对所述请求反馈的至少一个目标业务接口;
调用目标业务接口,执行所述第一任务。
5.根据权利要求1所述的方法,其特征在于,获取与第一任务对应的任务脚本,包括:
在检测到与所述第一任务对应的立即执行指令时,获取与所述第一任务对应的任务脚本。
6.根据权利要求1所述的方法,其特征在于,获取与第一任务对应的任务脚本,还包括:
在检测到与所述第一任务对应的定时执行指令时,获取目标调度;
启动所述目标调度,并通过所述目标调度,获取与所述第一任务对应的任务脚本。
7.根据权利要求6所述的方法,获取目标调度,包括:
如果确定存在空闲调度,则将与所述空闲调度连接的任务变更为所述第一任务,并将所述空闲调度作为目标调度;
如果确定不存在空闲调度,则创建新调度,将所述新调度与所述第一任务进行连接,并将所述新调度作为目标调度。
8.根据权利要求2-7任一项所述的方法,其特征在于,
在响应于用户在所述人机交互界面中输入的任务配置信息,生成所述第一任务之后,还包括:创建第一调度工作模块,并通过所述第一调度工作模块执行针对所述第一任务的任务调度方法;
所述方法,还包括:
响应于用户在所述人机交互界面中输入的任务配置信息,生成第二任务;
创建第二调度工作模块,并通过所述第二调度工作模块执行针对所述第二任务的任务调度方法。
9.一种任务调度装置,其特征在于,包括:
任务脚本获取模块,用于获取与第一任务对应的任务脚本;
第一任务类型确定模块,用于在所述任务脚本中解析任务配置指令,并根据所述任务配置指令确定第一任务类型;
第一任务执行模块,用于根据与所述第一任务类型匹配的任务处理策略,以及所述任务脚本,执行所述第一任务,并对所述第一任务的执行结果在人机交互界面中进行展示。
10.一种计算机设备,包括存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,其特征在于,所述处理器执行所述程序时实现如权利要求1-8中任一所述的任务调度方法。
11.一种包含计算机可执行指令的存储介质,其特征在于,所述计算机可执行指令在由计算机处理器执行时用于执行如权利要求1-8中任一所述的任务调度方法。
CN201911207006.5A 2019-11-29 2019-11-29 一种任务调度方法、装置、计算机设备和存储介质 Pending CN111026530A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201911207006.5A CN111026530A (zh) 2019-11-29 2019-11-29 一种任务调度方法、装置、计算机设备和存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201911207006.5A CN111026530A (zh) 2019-11-29 2019-11-29 一种任务调度方法、装置、计算机设备和存储介质

Publications (1)

Publication Number Publication Date
CN111026530A true CN111026530A (zh) 2020-04-17

Family

ID=70203655

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201911207006.5A Pending CN111026530A (zh) 2019-11-29 2019-11-29 一种任务调度方法、装置、计算机设备和存储介质

Country Status (1)

Country Link
CN (1) CN111026530A (zh)

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111586043A (zh) * 2020-05-07 2020-08-25 广东培正学院 一种计算机设备运维管理系统
CN113344550A (zh) * 2021-06-30 2021-09-03 西安力传智能技术有限公司 一种流程处理方法、装置、设备及存储介质
CN113447059A (zh) * 2021-06-03 2021-09-28 北京百度网讯科技有限公司 自动驾驶汽车传感器的检测方法、装置及电子设备
CN113641397A (zh) * 2021-10-12 2021-11-12 湖南映客互娱网络信息有限公司 带操作界面的脚本服务管理系统及管理方法
CN115842846A (zh) * 2022-11-25 2023-03-24 中国船舶重工集团公司第七一九研究所 一种适用于智能船舶的区域控制装置
CN113806651B (zh) * 2021-09-18 2024-05-24 深圳市酷开网络科技股份有限公司 一种数据缓存方法、装置、服务器及存储介质

Citations (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2009073872A1 (en) * 2007-12-06 2009-06-11 Artoftest, Inc. Systems, program product, and methods to enable visual recording and editing of test automation scenarios for markup applications
CN101694626A (zh) * 2009-09-30 2010-04-14 曙光信息产业(北京)有限公司 脚本执行系统及方法
CN105373428A (zh) * 2015-12-09 2016-03-02 北京奇虎科技有限公司 一种任务调度方法和系统
CN106156307A (zh) * 2016-06-30 2016-11-23 北京奇虎科技有限公司 一种实时计算平台的数据处理系统和方法
CN106649053A (zh) * 2016-12-28 2017-05-10 北京奇艺世纪科技有限公司 一种任务运行状态信息获得方法及装置
CN107403334A (zh) * 2017-06-07 2017-11-28 北京小度信息科技有限公司 数据处理方法及装置
CN107608772A (zh) * 2017-08-23 2018-01-19 山东中创软件工程股份有限公司 一种批处理任务配置调度的方法和系统
CN109582301A (zh) * 2018-12-03 2019-04-05 深圳前海微众银行股份有限公司 基于任务调度系统的业务处理方法、装置、设备及介质
CN109634728A (zh) * 2018-11-16 2019-04-16 深圳市云智融科技有限公司 作业调度方法、装置、终端设备及可读存储介质
CN109743390A (zh) * 2019-01-04 2019-05-10 深圳壹账通智能科技有限公司 任务调度方法、装置、计算机设备和存储介质
CN109814995A (zh) * 2019-01-04 2019-05-28 深圳壹账通智能科技有限公司 任务调度方法、装置、计算机设备和存储介质

Patent Citations (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2009073872A1 (en) * 2007-12-06 2009-06-11 Artoftest, Inc. Systems, program product, and methods to enable visual recording and editing of test automation scenarios for markup applications
CN101694626A (zh) * 2009-09-30 2010-04-14 曙光信息产业(北京)有限公司 脚本执行系统及方法
CN105373428A (zh) * 2015-12-09 2016-03-02 北京奇虎科技有限公司 一种任务调度方法和系统
CN106156307A (zh) * 2016-06-30 2016-11-23 北京奇虎科技有限公司 一种实时计算平台的数据处理系统和方法
CN106649053A (zh) * 2016-12-28 2017-05-10 北京奇艺世纪科技有限公司 一种任务运行状态信息获得方法及装置
CN107403334A (zh) * 2017-06-07 2017-11-28 北京小度信息科技有限公司 数据处理方法及装置
CN107608772A (zh) * 2017-08-23 2018-01-19 山东中创软件工程股份有限公司 一种批处理任务配置调度的方法和系统
CN109634728A (zh) * 2018-11-16 2019-04-16 深圳市云智融科技有限公司 作业调度方法、装置、终端设备及可读存储介质
CN109582301A (zh) * 2018-12-03 2019-04-05 深圳前海微众银行股份有限公司 基于任务调度系统的业务处理方法、装置、设备及介质
CN109743390A (zh) * 2019-01-04 2019-05-10 深圳壹账通智能科技有限公司 任务调度方法、装置、计算机设备和存储介质
CN109814995A (zh) * 2019-01-04 2019-05-28 深圳壹账通智能科技有限公司 任务调度方法、装置、计算机设备和存储介质

Cited By (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111586043A (zh) * 2020-05-07 2020-08-25 广东培正学院 一种计算机设备运维管理系统
CN111586043B (zh) * 2020-05-07 2022-08-19 广东培正学院 一种计算机设备运维管理系统
CN113447059A (zh) * 2021-06-03 2021-09-28 北京百度网讯科技有限公司 自动驾驶汽车传感器的检测方法、装置及电子设备
CN113447059B (zh) * 2021-06-03 2022-11-29 北京百度网讯科技有限公司 自动驾驶汽车传感器的检测方法、装置及电子设备
CN113344550A (zh) * 2021-06-30 2021-09-03 西安力传智能技术有限公司 一种流程处理方法、装置、设备及存储介质
CN113344550B (zh) * 2021-06-30 2023-11-28 西安力传智能技术有限公司 一种流程处理方法、装置、设备及存储介质
CN113806651B (zh) * 2021-09-18 2024-05-24 深圳市酷开网络科技股份有限公司 一种数据缓存方法、装置、服务器及存储介质
CN113641397A (zh) * 2021-10-12 2021-11-12 湖南映客互娱网络信息有限公司 带操作界面的脚本服务管理系统及管理方法
CN113641397B (zh) * 2021-10-12 2021-12-21 湖南映客互娱网络信息有限公司 带操作界面的脚本服务管理系统及管理方法
CN115842846A (zh) * 2022-11-25 2023-03-24 中国船舶重工集团公司第七一九研究所 一种适用于智能船舶的区域控制装置
CN115842846B (zh) * 2022-11-25 2024-05-03 中国船舶重工集团公司第七一九研究所 一种适用于智能船舶的区域控制装置

Similar Documents

Publication Publication Date Title
CN111026530A (zh) 一种任务调度方法、装置、计算机设备和存储介质
CN109636309B (zh) 任务处理方法及装置、电子设备及存储介质
CN107729139B (zh) 一种并发获取资源的方法和装置
CN104598513B (zh) 一种基于网页框架的数据流控制方法和系统
JP2018527683A (ja) 端末アプリケーションをロードする方法及び装置
CN113220431B (zh) 跨云的分布式数据任务调度方法、设备及存储介质
WO2018000678A1 (zh) 模块流程化调度方法及装置
CN110716848A (zh) 数据收集方法、装置、电子设备及存储介质
CN112765166A (zh) 数据处理方法、装置及计算机可读存储介质
CN110764894A (zh) 一种定时任务管理方法、装置、设备及存储介质
CN106060189B (zh) 一种分布式域名注册系统
CN110908793A (zh) 长时任务执行方法、装置、设备及可读存储介质
CN116089040A (zh) 业务流程的调度方法及其装置、电子设备及存储介质
CN108399095B (zh) 支持动态管理定时任务的方法、系统、设备和存储介质
CN111078383A (zh) 一种定时任务的管理方法、装置、设备及存储介质
CN111159300A (zh) 基于区块链的数据处理方法及装置
CN106445936A (zh) 一种数据处理方法及设备
WO2024139011A1 (zh) 信息处理方法
WO2024037132A1 (zh) 工作流处理方法、装置、设备、存储介质和程序产品
CN113743879A (zh) 一种自动化规则处理方法、系统以及相关设备
CN112367205B (zh) 一种对http调度请求的处理方法及调度系统
CN111679899B (zh) 任务调度方法、装置、平台设备及存储介质
CN111190725B (zh) 任务处理方法、装置、存储介质及服务器
CN113204540A (zh) 一种规则引擎配置方法、装置、设备及存储介质
CN113722228A (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

Application publication date: 20200417

RJ01 Rejection of invention patent application after publication