CN111597032A - 任务调度管理方法、装置及电子设备 - Google Patents
任务调度管理方法、装置及电子设备 Download PDFInfo
- Publication number
- CN111597032A CN111597032A CN202010458650.6A CN202010458650A CN111597032A CN 111597032 A CN111597032 A CN 111597032A CN 202010458650 A CN202010458650 A CN 202010458650A CN 111597032 A CN111597032 A CN 111597032A
- Authority
- CN
- China
- Prior art keywords
- target
- task
- working state
- state
- work
- 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.)
- Granted
Links
- 238000007726 management method Methods 0.000 title claims abstract description 35
- 238000012544 monitoring process Methods 0.000 claims abstract description 62
- 238000000034 method Methods 0.000 claims description 35
- 238000004364 calculation method Methods 0.000 claims description 24
- 238000006243 chemical reaction Methods 0.000 claims description 8
- 238000004590 computer program Methods 0.000 claims description 8
- 238000004806 packaging method and process Methods 0.000 claims description 3
- 230000002688 persistence Effects 0.000 description 12
- 230000008859 change Effects 0.000 description 10
- 238000010586 diagram Methods 0.000 description 9
- 230000008569 process Effects 0.000 description 7
- 230000006870 function Effects 0.000 description 4
- 230000002093 peripheral effect Effects 0.000 description 4
- 238000012545 processing Methods 0.000 description 4
- 230000009471 action Effects 0.000 description 3
- 230000002085 persistent effect Effects 0.000 description 3
- 238000004891 communication Methods 0.000 description 2
- 238000002955 isolation Methods 0.000 description 2
- 238000013507 mapping Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 238000007781 pre-processing Methods 0.000 description 2
- 230000002829 reductive effect Effects 0.000 description 2
- 238000011160 research Methods 0.000 description 2
- 230000008901 benefit Effects 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 230000002452 interceptive effect Effects 0.000 description 1
- 230000002427 irreversible effect Effects 0.000 description 1
- 230000000670 limiting effect Effects 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000008520 organization Effects 0.000 description 1
- 238000012856 packing Methods 0.000 description 1
- 238000003672 processing method Methods 0.000 description 1
- 230000003252 repetitive effect Effects 0.000 description 1
- 230000002441 reversible effect Effects 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
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
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3003—Monitoring arrangements specially adapted to the computing system or computing system component being monitored
- G06F11/302—Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system component is a software system
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computing Systems (AREA)
- Mathematical Physics (AREA)
- Quality & Reliability (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
本申请提供了一种任务调度管理方法、装置及电子设备,其中,该任务调度管理方法包括:使用目标监测组件对容器编排平台中的目标工作进行监控;当目标监测组件监控到目标工作的工作状态发生变化时,则通过目标监测组件将目标工作的当前工作状态发送给任务记录组件;通过任务记录组件,根据目标工作的当前工作状态对目标工作对应的目标任务的任务状态进行更新。
Description
技术领域
本申请涉及计算机技术领域,具体而言,涉及一种任务调度管理方法、装置及电子设备。
背景技术
目前任务的调度一般使用任务调度系统(Task scheduler system,TSS)接收任务,对任务进行预处理,最后包装成工作部署到容器编排平台运行。但是这种任务调度处理方式可能带来一些问题,因为用户直接交互的是任务调度系统,容器编排平台对用户来说是透明的,所以他看到的任务状态是任务调度系统中任务的状态;而任务真正运行于的工作的状态确实未知的。
发明内容
有鉴于此,本申请实施例的目的在于提供一种任务调度管理方法、装置及电子设备。能够达到实现对容器编排平台中的工作实现记录的效果。
第一方面,本申请实施例提供了一种任务调度管理方法,包括:
使用目标监测组件对容器编排平台中的目标工作进行监控;
当所述目标监测组件监控到所述目标工作的工作状态发生变化时,则通过所述任务记录组件,根据所述目标工作的当前工作状态对所述目标工作对应的目标任务的任务状态进行更新。
在一可选的实施方式中,所述通过所述任务记录组件,根据所述目标工作的当前工作状态对所述目标工作对应的目标任务的任务状态进行更新的步骤,包括:
通过所述任务记录组件,根据所述目标工作的当前工作状态与所述目标工作对应的目标人物的任务状态,确定所述目标工作的当前工作状态是否为被记录过的工作状态;
若所述目标工作的当前工作状态未被记录过的工作状态,根据所述目标工作的当前工作状态对所述目标工作对应的目标任务的任务状态进行更新。
本申请实施例提供的任务调度管理方法,采用根据状态的计算,确定出目标工作的当前工作状态是否被记录过的工作状态,从而可以减少重复记录,从而可以使记录的流程准确率更高。
在一可选的实施方式中,所述根据所述目标工作的当前工作状态与所述目标工作对应的目标人物的任务状态,确定所述目标工作的当前工作状态是否为被记录过的工作状态的步骤,包括:
对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行第一计算,得到第一计算值;
根据所述第一计算值确定所述目标工作的当前工作状态是否为被记录过的工作状态。
在一可选的实施方式中,所述对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行第一计算,得到第一计算值的步骤,包括:
对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行按位与计算,得到第一计算值;
所述根据所述第一计算值确定所述目标工作的当前工作状态是否为被记录过的工作状态的步骤,包括:
将所述第一计算值转换成布尔类型的第二计算值;
判断所述第二计算值是否为真值,若第二计算值为真值,则目标工作的当前工作状态为被记录过的工作状态,若第二计算值为假真值,则目标工作的当前工作状态为被记录过的工作状态。
本申请实施例提供的任务调度管理方法,采用按位与的计算方式,确定出能够表示真假的数值,从而可以更简易的判断是否被记录过。
在一可选的实施方式中,所述通过所述任务记录组件,根据所述目标工作的当前工作状态对所述目标工作对应的目标任务的任务状态进行更新的步骤,包括:
通过所述任务记录组件,对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行第二计算,得到所述目标任务更新后的第三标志位。
在一可选的实施方式中,所述通过所述任务记录组件,对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态进行第二计算,得到所述目标任务更新后的第三标志位的步骤,包括:
通过所述任务记录组件,对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行按位或计算,得到所述目标任务更新后的第三标志位。
本申请实施例提供的任务调度管理方法,采用按位或的计算方式,可以使任务的状态的更新更方便,也使前后的状态能够关联上。
在一可选的实施方式中,在所述使用目标监测组件对容器编排平台中的目标工作进行监控的步骤之前,所述方法还包括:
通过任务转换组件对接收到的所述目标任务打包成一所述目标工作,并将所述目标工作发送给所述容器编排平台;
启动所述目标监测组件,用于对所述目标工作进行监控。
本申请实施例提供的任务调度管理方法,采用每一工作对应一监测组件对工作进行监控,从而可以使监控流程更有序,监控准确率更高。
第二方面,本申请实施例还提供一种任务调度管理装置,包括:
监测模块,用于使用目标监测组件对容器编排平台中的目标工作进行监控;
更新模块,用于当所述目标监测组件监控到所述目标工作的工作状态发生变化时,则通过所述任务记录组件,根据所述目标工作的当前工作状态对所述目标工作对应的目标任务的任务状态进行更新。
第三方面,本申请实施例还提供一种电子设备,包括:处理器、存储器,所述存储器存储有所述处理器可执行的机器可读指令,当电子设备运行时,所述机器可读指令被所述处理器执行时执行上述第一方面,或第一方面的任一种可能的实施方式中的方法的步骤。
第四方面,本申请实施例还提供一种计算机可读存储介质,该计算机可读存储介质上存储有计算机程序,该计算机程序被处理器运行时执行上述第一方面,或第一方面的任一种可能的实施方式中的方法的步骤。
本申请实施例提供的任务调度管理方法、装置、电子设备及计算机可读存储介质,采用专门的监测组件对容器编排平台中的目标工作进行监控,并根据监控到的状态对任务状态进行更新,从而可以使工作状态与任务状态关联起来,从而使用户可以通过任务状态了解到工作状态,从而是透明的工作状态也变成可获知的状态。
为使本申请的上述目的、特征和优点能更明显易懂,下文特举实施例,并配合所附附图,作详细说明如下。
附图说明
为了更清楚地说明本申请实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本申请的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
图1为本申请实施例提供的电子设备的方框示意图。
图2为本申请实施例提供的电子设备中的任务调度系统的方框示意图。
图3为本申请实施例提供的任务调度管理方法的流程图。
图4为本申请实施例提供的另一任务调度管理方法的流程图。
图5为本申请实施例提供的任务调度管理装置的功能模块示意图。
具体实施方式
下面将结合本申请实施例中附图,对本申请实施例中的技术方案进行描述。
应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。同时,在本申请的描述中,术语“第一”、“第二”等仅用于区分描述,而不能理解为指示或暗示相对重要性。
现有的任务调度系统Yarn,使用Cgroup为每个container限制其可使用的CPU与内存,从而做到资源的限制。此外Yarn为各节点的本地化资源做了访问限制,分为PUBLIC(所有人都能访问),PRIVATE(资源所有者能访问),APPLICATION(只有特定的任务能够访问)。但是Yarn的这种基于POSIX用户权限的隔离机制没有做到真正的命名空间隔离。
与Yarn相比,Kubernetes与Swarm通过使用docker解决了资源限制与隔离的问题。但是这两者都不算严格意义上的任务调度系统,而是容器编排平台(Containerorchestration platform,COP),提交到Kubernetes和Swarm上的不是一个任务,而是一个docker容器的描述。
基于上述研究,提供了一种新的任务调度方式,通过将任务与工作分离,使用TSS接收任务(Task),对Task进行预处理,最后包装成工作(Job)部署到COP运行。但是用户直接交互的是TSS,COP对用户来说是透明的,所以用户看到的任务状态都是TSS中任务状态。而任务真正运行于COP的工作的工作状态。基于上述研究,本申请实施例提供了一种任务调度管理方法、装置、电子设备及计算机可读存储介质,能够实现将COP中的工作状态与TSS中的任务状态关联起来,从而可以使用户能获知COP中的工作状态。
实施例一
为便于对本实施例进行理解,首先对执行本申请实施例所公开的任务调度管理方法的电子设备进行详细介绍。
如图1所示,是电子设备的方框示意图。电子设备100可以包括存储器111、存储控制器112、处理器113、外设接口114、输入输出单元115、显示单元116。本领域普通技术人员可以理解,图1所示的结构仅为示意,其并不对电子设备100的结构造成限定。例如,电子设备100还可包括比图1中所示更多或者更少的组件,或者具有与图1所示不同的配置。
上述的存储器111、存储控制器112、处理器113、外设接口114、输入输出单元115及显示单元116各元件相互之间直接或间接地电性连接,以实现数据的传输或交互。例如,这些元件相互之间可通过一条或多条通讯总线或信号线实现电性连接。上述的处理器113用于执行存储器中存储的可执行模块。
其中,存储器111可以是,但不限于,随机存取存储器(Random Access Memory,简称RAM),只读存储器(Read Only Memory,简称ROM),可编程只读存储器(ProgrammableRead-Only Memory,简称PROM),可擦除只读存储器(Erasable Programmable Read-OnlyMemory,简称EPROM),电可擦除只读存储器(Electric Erasable Programmable Read-OnlyMemory,简称EEPROM)等。其中,存储器111用于存储程序,所述处理器113在接收到执行指令后,执行所述程序,本申请实施例任一实施例揭示的过程定义的电子设备100所执行的方法可以应用于处理器113中,或者由处理器113实现。
上述的处理器113可能是一种集成电路芯片,具有信号的处理能力。上述的处理器113可以是通用处理器,包括中央处理器(Central Processing Unit,简称CPU)、网络处理器(Network Processor,简称NP)等;还可以是数字信号处理器(digital signalprocessor,简称DSP)、专用集成电路(Application Specific Integrated Circuit,简称ASIC)、现场可编程门阵列(FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本申请实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
本实施例中的电子设备100的存储器111中可以存储有多个组件。如图2所示,示例性地,存储器111可以包括:容器编排平台(Container orchestration platform,COP)250,用于对接收到的工作进行执行;任务调度系统(Task scheduler system,TSS),用于对任务进行一些预处理。其中,任务调度系统可以包括:任务缓存组件(TaskQueue)210,用于对接收到的任务进行缓存;任务转换组件(JobDispatcher)220,用于对接收到的任务转换成工作;监测组件(JobMonitor)230,用于对容器编排平台中的工作进行监控;以及任务持久化组件(TaskMeta)240,用于对任务状态的持久化处理。可选地,存储器111中还可以存储有工作持久化组件(JobMeta)260,用于对工作状态的持久化处理。其中,存储器111中的组件可以由处理器113调用执行。
上述的外设接口114将各种输入/输出装置耦合至处理器113以及存储器111。在一些实施例中,外设接口114,处理器113以及存储控制器112可以在单个芯片中实现。在其他一些实例中,他们可以分别由独立的芯片实现。
上述的输入输出单元115用于提供给用户输入数据。所述输入输出单元115可以是,但不限于,鼠标和键盘等。
上述的显示单元116在电子设备100与用户之间提供一个交互界面(例如用户操作界面)或用于显示图像数据给用户参考。在本实施例中,所述显示单元可以是液晶显示器或触控显示器。若为触控显示器,其可为支持单点和多点触控操作的电容式触控屏或电阻式触控屏等。支持单点和多点触控操作是指触控显示器能感应到来自该触控显示器上一个或多个位置处同时产生的触控操作,并将该感应到的触控操作交由处理器进行计算和处理。
本实施例中的电子设备100可以用于执行本申请实施例提供的各个方法中的各个步骤。下面通过几个实施例详细描述任务调度管理方法的实现过程。
实施例二
请参阅图3,是本申请实施例提供的任务调度管理方法的流程图。下面将对图3所示的具体流程进行详细阐述。
步骤302,使用目标监测组件对容器编排平台中的目标工作进行监控。
本实施例中,每一工作可以对应有一监测组件,以实现一对一的监控。
在步骤302之前,如图4所示,任务调度管理方法还可以包括以下步骤。
步骤3011,通过任务转换组件对接收到的所述目标任务打包成一所述目标工作,并将所述目标工作发送给所述容器编排平台。
可选地,任务转换组件从任务缓存组件中获取一项任务,然后将获取的任务包装成工作,发送给容器编排平台,由容器编排平台执行。
步骤3012,启动所述目标监测组件,用于对所述目标工作进行监控。
本实施例中,任务转换组件每成功发送一个工作给容器编排平台后,则可以启动一项监测组件,对发送成功的工作的状态变化事件。
本实施例中,容器编排平台中的工作的状态发生变化时,可以将状态变化事件持久化至工作持久化组件中。因此,监测组件可以通过与工作持久化组件的通信连接,获取工作的状态变化事件。
可选地,监测组件可以与工作持久化组件建立长连接,以实时地获取工作的状态变化事件。当工作持久化组件中的指定工作存在新的状态变化事件时,监控该指定工作的指定监测组件就能够监测到状态变化事件。
步骤304,当所述目标监测组件监控到所述目标工作的工作状态发生变化时,则通过所述任务记录组件,根据所述目标工作的当前工作状态对所述目标工作对应的目标任务的任务状态进行更新。
本实施例中,当目标监测组件监控到所述目标工作的工作状态发生变化时,驱动目标任务的状态变化。并将变化后的任务状态持久化到任务持久化组件中。
下面通过一个全流程描述目标工作的工作状态的变化后,对应目标任务的任务状态的更新流程。
示例性地,当目标工作的工作状态变为挂起(Pending),此时目标监测组件监测到挂起(Pending)事件,将会驱动目标任务的任务状态变为派遣(Dispatched),表示目标工作已在容器编排平台(COP)中排队等待运行。
当目标工作的工作状态变为进行中(Running),此时目标监测组件监测到进行中(Running)事件,将会驱动目标任务的任务状态变为进行中(Running),表示目标工作已在COP上运行。
当目标工作的工作状态变为成功(Succeeded),此时目标监测组件监测到成功(Succeeded)事件,将会驱动目标任务的任务状态变为完成(Done),表示目标工作已在COP上成功结束。
当目标工作的工作状态变为失败(Failed),此时目标监测组件监测到失败(Failed)事件,将会驱动目标任务的任务状态变为失败(Failed),表示目标工作已在COP上异常结束。
当目标工作的工作状态变为未知(Unknown),此时目标监测组件监测到未知(Unknown)事件,将会驱动目标任务的任务状态变为终止(Terminated),表示目标工作与COP失去联系,其状态是未知的。
通过上述的步骤能够实现将容器编排平台中的工作状态与任务调度系统中的任务状态关联起来。此外,监测组件与工作持久化组件的长连接可能存在不稳定的情况,例如,存在网络波动或系统故障时,则可能导致监测组件可以与工作持久化组件的长连接不稳定的问题。因此监测组件可以与工作持久化组件重新连接后,可以将所有已发生的工作状态变化事件重新获取一遍,从而可以避免错过工作状态变化事件。但是这种处理方式可能会产生一些重复的操作,例如,当一个任务状态已经变为进行中,而监控组件重连工作持久化组件后,则监控组件则会重新获取工作的挂起(Pending)状态和进行中(Running)状态这两个状态事件,此时,任务状态将会出现进行中->派遣->进行中这一错误的状态顺序。基于此研究,在对任务状态进行更新之前还可以确定当前监测到的工作状态是否为已经获知过的状态。则步骤304可以包括以下步骤。
步骤3041,通过所述任务记录组件,根据所述目标工作的当前工作状态与所述目标工作对应的目标人物的任务状态,确定所述目标工作的当前工作状态是否为被记录过的工作状态。
若所述目标工作的当前工作状态未被记录过的工作状态,则执行步骤3042。若所述目标工作的当前工作状态被记录过的工作状态,则可以跳过此次状态的更新。
在一种可选的实施方式中,步骤3041可以包括以下步骤。
步骤a,对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行第一计算,得到第一计算值。
在一种实施方式中,可以对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行按位与计算,得到第一计算值。
示例性地,工作的每项工作状态可以对应有一个唯一的状态标志位。在一个实例中,状态标志位的大小可以为1byte,各个工作状态对应的标志位可以如下表所示:
工作标志位名称 | 标志位值 | 工作状态 |
PENDINGFLAG | 0x01 | Pending |
RUNNING_FLAG | 0x02 | Running |
SUCCEEDED_FLAG | 0x04 | Succeeded |
FAILED_FLAG | 0x08 | Failed |
UNKNOWN_FLAG | 0x10 | Unknown |
而每个任务的状态也可以对应有唯一标志位,该唯一标志位的值可以是根据任务状态的前一状态的标志位及对应的工作状态的标志位计算得到。在一个实例中,任务状态的标志位可以采用以下表2所示的方式进行计算:
任务标志位名称 | 标志位值 | 对应任务状态 |
NEW_JOB_FLAG | 0x00 | 初始状态 |
PENDING_JOB_FLAG | NEW_JOB_FLAG|PENDING_FLAG | Dispatched |
RUNNING_JOB_FLAG | PENDING_JOB_FLAG|RUNNING_FLAG | Running |
SUCCEEDED_JOB_FLAG | RUNNING_JOB_FLAG|SUCCEEDED_FLAG | Done |
FAILED_JOB_FLAG | RUNNING_JOB_FLAG|FAILED_FLAG | Failed |
UNKNOWN_JOB_FLAG | RUNNING_JOB_FLAG|UNKNOWN_FLAG | Terminated |
在上述实例中,则可以将接收到的工作状态的标志位与当前记录的任务标志位进行计算。
示例性地,如果当前监测到的工作状态是Running,则Running对应的标志位是0x02,当前任务持久化组件中记录的任务状态为Done,则可以将Done对应的标志位与工作状态是Running的标志位进行按位与的计算:RUNNING_JOB_FLAG|SUCCEEDED_FLAG&0x02。再将RUNNING_JOB_FLAG|SUCCEEDED_FLAG&0x02转换为布尔型值。
步骤b,根据所述第一计算值确定所述目标工作的当前工作状态是否为被记录过的工作状态。
在一种实施方式中,将所述第一计算值转换成布尔类型的第二计算值,
判断所述第二计算值是否为真值,若第二计算值为真值,则目标工作的当前工作状态为被记录过的工作状态,若第二计算值为假真值,则目标工作的当前工作状态为被记录过的工作状态。
以上述实例为例,此时计算得到的布尔型值为真值,则可以确定工作状态Running已经获取过,则可以在接收到工作状态Running时,不对任务状态进行更新。
在一个实例中,当前任务的状态为RUNNING_JOB_FLAG,其转换为8bit形式为:00000011。此时获取了来了新的工作状态为Running,Running对应的标志位为RUNNING_FLAG,其转换为8bit形式为00000010,此时将RUNNING_JOB_FLAG与RUNNING_FLAG按位与,得到的结果是00000010,该结果转换为布尔类型为真值,表示监测组件已经监测到过工作状态Running,此时任务状态将不会根据工作状态为Running进行更新。再例如,若监测到工作状态Succeeded,对应的标志位为SUCCEEDED_FLAG,其转换为8bit形式为00000100,此时将RUNNING_JOB_FLAG与SUCCEEDED_FLAG按位与,得到的结果是00000000,该结果转换为布尔类型为假值,表示监测组件未监测到过工作状态Succeeded,此时任务状态将根据工作状态为Succeeded进行更新为Done,任务状态标志位变为SUCCEEDED_JOB_FLAG。
通过上述的检测方式,可以使任务状态的更新是不可逆的状态,具体可以如下表3所示:
例如,任务状态的当前标志位是PENDING_JOB_FLAG,在获取Running状态后,可以实现状态的更新,任务状态更新为RUNNING_JOB_FLAG;但是在获取Pending状态后,则任务状态不能被更新。
步骤3042,根据所述目标工作的当前工作状态对所述目标工作对应的目标任务的任务状态进行更新。
步骤3042,包括:通过所述任务记录组件,对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行第二计算,得到所述目标任务更新后的第三标志位。
在一种实施方式中,通过所述任务记录组件,对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行按位或计算,得到所述目标任务更新后的第三标志位。
在一个实例中,当前的任务状态可以是Running,监测到的工作状态改变为Succeeded,则可以任务状态可以是Running的标志位PENDING_JOB_FLAG|RUNNING_FLAG与工作状态Succeeded的标志位0x04进行按位或计算:PENDING_JOB_FLAG|RUNNING_FLAG|0x04,得到更新后的任务状态的标志位。
进一步地,在任务状态的标志位更新之后,任务状态变成Done。
根据本实施例中的方法,本申请实施例提供了任务调度系统与容器编排平台之间状态映射的方法,实现了将工作与任务的状态映射与实时同步,以及减少任务状态发生无效转换等问题,对任务调度系统与容器编排平台实现有效管理。
实施例三
基于同一申请构思,本申请实施例中还提供了与任务调度管理方法对应的任务调度管理装置,由于本申请实施例中的装置解决问题的原理与前述的任务调度管理方法实施例相似,因此本实施例中的装置的实施可以参见上述方法的实施例中的描述,重复之处不再赘述。
请参阅图5,是本申请实施例提供的任务调度管理装置的功能模块示意图。本实施例中的任务调度管理装置中的各个模块用于执行上述方法实施例中的各个步骤。任务调度管理装置包括:监测模块401、更新模块402;其中,
监测模块401,用于使用目标监测组件对容器编排平台中的目标工作进行监控;
更新模块402,用于当所述目标监测组件监控到所述目标工作的工作状态发生变化时,则通过所述任务记录组件,根据所述目标工作的当前工作状态对所述目标工作对应的目标任务的任务状态进行更新。
一种可能的实施方式中,更新模块402,包括:确定单元和更新单元;
确定单元,用于通过所述任务记录组件,根据所述目标工作的当前工作状态与所述目标工作对应的目标人物的任务状态,确定所述目标工作的当前工作状态是否为被记录过的工作状态;
更新单元,用于若所述目标工作的当前工作状态未被记录过的工作状态,根据所述目标工作的当前工作状态对所述目标工作对应的目标任务的任务状态进行更新。
一种可能的实施方式中,确定单元,用于:
对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行第一计算,得到第一计算值;
根据所述第一计算值确定所述目标工作的当前工作状态是否为被记录过的工作状态。
一种可能的实施方式中,确定单元,用于:
对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行按位与计算,得到第一计算值;
将所述第一计算值转换成布尔类型的第二计算值;
判断所述第二计算值是否为真值,若第二计算值为真值,则目标工作的当前工作状态为被记录过的工作状态,若第二计算值为假真值,则目标工作的当前工作状态为被记录过的工作状态。
一种可能的实施方式中,更新模块402,用于:
通过所述任务记录组件,对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行第二计算,得到所述目标任务更新后的第三标志位。
一种可能的实施方式中,更新模块402,用于:
通过所述任务记录组件,对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行按位或计算,得到所述目标任务更新后的第三标志位。
一种可能的实施方式中,任务调度管理装置还可以包括:
打包模块403,用于通过任务转换组件对接收到的所述目标任务打包成一所述目标工作,并将所述目标工作发送给所述容器编排平台;
启动模块404,用于启动所述目标监测组件,用于对所述目标工作进行监控。
此外,本申请实施例还提供一种计算机可读存储介质,该计算机可读存储介质上存储有计算机程序,该计算机程序被处理器运行时执行上述方法实施例中所述的任务调度管理方法的步骤。
本申请实施例所提供的任务调度管理方法的计算机程序产品,包括存储了程序代码的计算机可读存储介质,所述程序代码包括的指令可用于执行上述方法实施例中所述的任务调度管理方法的步骤,具体可参见上述方法实施例,在此不再赘述。
在本申请所提供的几个实施例中,应该理解到,所揭露的装置和方法,也可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,附图中的流程图和框图显示了根据本申请的多个实施例的装置、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段或代码的一部分,所述模块、程序段或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现方式中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个连续的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或动作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
另外,在本申请各个实施例中的各功能模块可以集成在一起形成一个独立的部分,也可以是各个模块单独存在,也可以两个或两个以上模块集成形成一个独立的部分。
所述功能如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本申请各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
以上所述仅为本申请的优选实施例而已,并不用于限制本申请,对于本领域的技术人员来说,本申请可以有各种更改和变化。凡在本申请的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本申请的保护范围之内。应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。
以上所述,仅为本申请的具体实施方式,但本申请的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本申请揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本申请的保护范围之内。因此,本申请的保护范围应以权利要求的保护范围为准。
Claims (10)
1.一种任务调度管理方法,其特征在于,包括:
使用目标监测组件对容器编排平台中的目标工作进行监控;
当所述目标监测组件监控到所述目标工作的工作状态发生变化时,则通过所述任务记录组件,根据所述目标工作的当前工作状态对所述目标工作对应的目标任务的任务状态进行更新。
2.根据权利要求1所述的方法,其特征在于,所述通过所述任务记录组件,根据所述目标工作的当前工作状态对所述目标工作对应的目标任务的任务状态进行更新的步骤,包括:
通过所述任务记录组件,根据所述目标工作的当前工作状态与所述目标工作对应的目标人物的任务状态,确定所述目标工作的当前工作状态是否为被记录过的工作状态;
若所述目标工作的当前工作状态未被记录过的工作状态,根据所述目标工作的当前工作状态对所述目标工作对应的目标任务的任务状态进行更新。
3.根据权利要求2所述的方法,其特征在于,所述根据所述目标工作的当前工作状态与所述目标工作对应的目标人物的任务状态,确定所述目标工作的当前工作状态是否为被记录过的工作状态的步骤,包括:
对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行第一计算,得到第一计算值;
根据所述第一计算值确定所述目标工作的当前工作状态是否为被记录过的工作状态。
4.根据权利要求3所述的方法,其特征在于,所述对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行第一计算,得到第一计算值的步骤,包括:
对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行按位与计算,得到第一计算值;
所述根据所述第一计算值确定所述目标工作的当前工作状态是否为被记录过的工作状态的步骤,包括:
将所述第一计算值转换成布尔类型的第二计算值;
判断所述第二计算值是否为真值,若第二计算值为真值,则目标工作的当前工作状态为被记录过的工作状态,若第二计算值为假真值,则目标工作的当前工作状态为被记录过的工作状态。
5.根据权利要求1或2所述的方法,其特征在于,所述通过所述任务记录组件,根据所述目标工作的当前工作状态对所述目标工作对应的目标任务的任务状态进行更新的步骤,包括:
通过所述任务记录组件,对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行第二计算,得到所述目标任务更新后的第三标志位。
6.根据权利要求5所述的方法,其特征在于,所述通过所述任务记录组件,对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态进行第二计算,得到所述目标任务更新后的第三标志位的步骤,包括:
通过所述任务记录组件,对所述目标工作对应的目标任务的任务状态的第一标志位与所述目标工作的当前工作状态的第二标志位进行按位或计算,得到所述目标任务更新后的第三标志位。
7.根据权利要求1所述的方法,其特征在于,在所述使用目标监测组件对容器编排平台中的目标工作进行监控的步骤之前,所述方法还包括:
通过任务转换组件对接收到的所述目标任务打包成一所述目标工作,并将所述目标工作发送给所述容器编排平台;
启动所述目标监测组件,用于对所述目标工作进行监控。
8.一种任务调度管理装置,其特征在于,包括:
监测模块,用于使用目标监测组件对容器编排平台中的目标工作进行监控;
更新模块,用于当所述目标监测组件监控到所述目标工作的工作状态发生变化时,则通过所述任务记录组件,根据所述目标工作的当前工作状态对所述目标工作对应的目标任务的任务状态进行更新。
9.一种电子设备,其特征在于,包括:处理器、存储器,所述存储器存储有所述处理器可执行的机器可读指令,当电子设备运行时,所述机器可读指令被所述处理器执行时执行如权利要求1至7任一所述的方法的步骤。
10.一种计算机可读存储介质,其特征在于,该计算机可读存储介质上存储有计算机程序,该计算机程序被处理器运行时执行如权利要求1至7任一所述的方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010458650.6A CN111597032B (zh) | 2020-05-26 | 2020-05-26 | 任务调度管理方法、装置及电子设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010458650.6A CN111597032B (zh) | 2020-05-26 | 2020-05-26 | 任务调度管理方法、装置及电子设备 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111597032A true CN111597032A (zh) | 2020-08-28 |
CN111597032B CN111597032B (zh) | 2024-03-26 |
Family
ID=72190598
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010458650.6A Active CN111597032B (zh) | 2020-05-26 | 2020-05-26 | 任务调度管理方法、装置及电子设备 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111597032B (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112486656A (zh) * | 2020-12-10 | 2021-03-12 | 上海创远仪器技术股份有限公司 | 实现无线电离线任务调度和数据下载的方法 |
CN113641549A (zh) * | 2021-03-08 | 2021-11-12 | 万翼科技有限公司 | 任务监控方法、装置、电子设备和存储介质 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2016060700A1 (en) * | 2014-10-17 | 2016-04-21 | Hewlett Packard Enterprise Development Lp | File system journaling |
WO2017148283A1 (zh) * | 2016-02-29 | 2017-09-08 | 广州市动景计算机科技有限公司 | 状态信息管理系统、方法及电子设备 |
WO2017181876A1 (zh) * | 2016-04-19 | 2017-10-26 | 华为技术有限公司 | 一种设备状态及资源信息监测方法、相关设备及系统 |
CN110618864A (zh) * | 2019-09-19 | 2019-12-27 | 北京明略软件系统有限公司 | 一种中断任务恢复方法及装置 |
-
2020
- 2020-05-26 CN CN202010458650.6A patent/CN111597032B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2016060700A1 (en) * | 2014-10-17 | 2016-04-21 | Hewlett Packard Enterprise Development Lp | File system journaling |
WO2017148283A1 (zh) * | 2016-02-29 | 2017-09-08 | 广州市动景计算机科技有限公司 | 状态信息管理系统、方法及电子设备 |
WO2017181876A1 (zh) * | 2016-04-19 | 2017-10-26 | 华为技术有限公司 | 一种设备状态及资源信息监测方法、相关设备及系统 |
CN110618864A (zh) * | 2019-09-19 | 2019-12-27 | 北京明略软件系统有限公司 | 一种中断任务恢复方法及装置 |
Non-Patent Citations (1)
Title |
---|
宁新建;: "机载多目标攻击作战飞行程序研究" * |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112486656A (zh) * | 2020-12-10 | 2021-03-12 | 上海创远仪器技术股份有限公司 | 实现无线电离线任务调度和数据下载的方法 |
CN113641549A (zh) * | 2021-03-08 | 2021-11-12 | 万翼科技有限公司 | 任务监控方法、装置、电子设备和存储介质 |
CN113641549B (zh) * | 2021-03-08 | 2024-05-17 | 万翼科技有限公司 | 任务监控方法、装置、电子设备和存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN111597032B (zh) | 2024-03-26 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10348809B2 (en) | Naming of distributed business transactions | |
US20190303779A1 (en) | Digital worker management system | |
CN105357038B (zh) | 监控虚拟机集群的方法和系统 | |
TWI838596B (zh) | 管理物流資訊之電子設備及其控制方法 | |
JP5422342B2 (ja) | インシデント管理方法および運用管理サーバ | |
US9015731B2 (en) | Event handling system and method | |
CN109033814B (zh) | 智能合约触发方法、装置、设备及存储介质 | |
US9910710B2 (en) | Prioritising event processing based on system workload | |
US10114731B2 (en) | Including kernel object information in a user dump | |
CN111597032A (zh) | 任务调度管理方法、装置及电子设备 | |
KR101212496B1 (ko) | 모니터링 자원의 사용량 표현 방법, 컴퓨팅 장치 및 그 방법을 실행시키기 위한 프로그램을 기록한 기록 매체 | |
JP2012080181A (ja) | 障害情報管理方法および障害情報管理プログラム | |
US9210043B2 (en) | Recommending a policy for an IT asset | |
US11086669B2 (en) | System and method for sorting and scheduling workflows | |
US8275865B2 (en) | Methods, systems and computer program products for selecting among alert conditions for resource management systems | |
JP2006344061A (ja) | シナリオ適用支援方法、管理サーバおよび管理プログラム | |
US7188093B2 (en) | Methods and systems for determining circular dependency | |
TW202226092A (zh) | 基於預期結果值提供資訊之方法及使用該方法之計算裝置 | |
CN110837399A (zh) | 一种管理流式计算应用程序的方法、装置及计算设备 | |
JP7109687B2 (ja) | 情報生成装置、情報生成方法、及び、情報生成プログラム | |
US11144369B2 (en) | Preemptive self-healing of application server hanging threads | |
JP2023176817A (ja) | 対処支援装置および対処支援方法 | |
CN111090528A (zh) | 死锁确定方法、装置及电子设备 | |
WO2019036101A1 (en) | CORRELATION OF FUNCTION CALLS WITH FUNCTIONS IN ASYNCHRONOUSLY EXECUTED SONES |
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 | ||
CB02 | Change of applicant information | ||
CB02 | Change of applicant information |
Country or region after: China Address after: Building 4, No. 15 Haidian Middle Street, Haidian District, Beijing, 100000, Floor 1-5, 1st Floor Applicant after: Beijing minglue Zhaohui Technology Co.,Ltd. Address before: Room 2020, 2nd floor, building 27, 25 North Third Ring Road West, Haidian District, Beijing Applicant before: BEIJING SUPERTOOL INTERNET TECHNOLOGY LTD. Country or region before: China |
|
GR01 | Patent grant | ||
GR01 | Patent grant |