CN115599300A - 一种任务分配方法、装置、设备及介质 - Google Patents

一种任务分配方法、装置、设备及介质 Download PDF

Info

Publication number
CN115599300A
CN115599300A CN202211292977.6A CN202211292977A CN115599300A CN 115599300 A CN115599300 A CN 115599300A CN 202211292977 A CN202211292977 A CN 202211292977A CN 115599300 A CN115599300 A CN 115599300A
Authority
CN
China
Prior art keywords
task
node
nodes
distribution
information
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
CN202211292977.6A
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.)
Inspur Jinan data Technology Co ltd
Original Assignee
Inspur Jinan data 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 Inspur Jinan data Technology Co ltd filed Critical Inspur Jinan data Technology Co ltd
Priority to CN202211292977.6A priority Critical patent/CN115599300A/zh
Publication of CN115599300A publication Critical patent/CN115599300A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/067Distributed or networked storage systems, e.g. storage area networks [SAN], network attached storage [NAS]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0629Configuration or reconfiguration of storage systems
    • 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/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5011Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resources being hardware resources other than CPUs, Servers and Terminals

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Software Systems (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本申请公开了一种任务分配方法、装置、设备及介质,涉及分布式存储领域。通过在分布式存储集群中创建任务记录对象,创建各节点对应的任务管理服务;根据任务记录对象在各节点中选取任务分配节点;根据任务记录对象和任务分配节点判断是否接收到任务;若是,通过任务分配节点分配任务至目标节点,以用于目标节点通过对应的任务管理服务对任务进行处理。由此可知,上述方案通过在分布式存储集群中创建任务记录对象记录任务,并在全部节点中选取任务分配节点用于任务分配;当接收到任务时,由任务分配节点将任务分配至存储集群中其他节点进行处理,避免了卷管理类操作集中在管理节点堆积执行,节省了节点资源,提高了分布式存储集群的整体稳定性。

Description

一种任务分配方法、装置、设备及介质
技术领域
本申请涉及分布式存储领域,特别是涉及一种任务分配方法、装置、设备及介质。
背景技术
对于客户来说,块存储的使用可以像使用物理硬盘一样格式化并建立任意文件***,所以块存储适用于大部分通用业务场景下的数据存储,并得到了越来越广泛的应用。
在块存储场景中,卷承担了主要的功能实现和业务输出。虽然分布式存储***采用了部分去中心化思维设计方式,但卷的管理类操作的任务仍需要在管理节点进行,大量的卷管理类操作的任务集中在管理节点堆积执行,可能造成管理节点***资源不足,影响分布式存储集群整体稳定性。
鉴于上述问题,如何避免分布式存储***中对卷的操作任务堆积于一个节点,以提升分布式存储集群的稳定性,是该领域技术人员亟待解决的问题。
发明内容
本申请的目的是提供一种任务分配方法、装置、设备及介质,实现分布式存储***中对卷的操作任务的分配,以提升分布式存储集群的稳定性。
为解决上述技术问题,本申请提供一种任务分配方法,包括:
在分布式存储集群中创建任务记录对象,以记录表征卷操作请求的任务的信息;
创建各节点对应的任务管理服务;
根据所述任务记录对象在各所述节点中选取任务分配节点;
根据所述任务记录对象和所述任务分配节点判断是否接收到所述任务;
若是,通过所述任务分配节点分配所述任务至目标节点,以用于所述目标节点通过对应的所述任务管理服务对所述任务进行处理。
优选地,在所述创建各节点对应的任务管理服务之后,在所述根据所述任务记录对象在各所述节点中选取任务分配节点之前,还包括:
通过各所述任务管理服务向所述任务记录对象注册对应的各所述节点的节点ID。
优选地,所述根据所述任务记录对象在各所述节点中选取任务分配节点包括:
基于所述任务记录对象创建分布式锁;
接收各所述节点通过对应的所述任务管理服务对所述分布式锁的申请;
分别判断各所述节点是否申请到所述分布式锁;
若是,则申请到所述分布式锁的所述节点为所述任务分配节点。
优选地,所述根据所述任务记录对象和所述任务分配节点判断是否接收到所述任务包括:
通过所述任务分配节点定时读取所述任务记录对象中的所述任务;
判断读取到的所述任务是否与任务列表中现有的所述任务相同;
若否,则确认接收到所述任务,获取所述任务的任务信息;其中,所述任务信息包括任务类型、源卷信息、目的卷信息和执行者ID;
设置所述任务的任务ID并添加至所述任务信息中;
将所述任务信息写入所述任务记录对象中,进入所述通过所述任务分配节点分配所述任务至目标节点的步骤。
优选地,所述通过所述任务分配节点分配所述任务至目标节点包括:
通过一致性哈希算法计算所述任务的所述任务ID,以将所述任务分配至所述目标节点;
将所述目标节点的所述节点ID写入所述任务的所述执行者ID的字段;
通过广播通知各所述节点刷新对应的所述任务列表。
优选地,所述目标节点通过对应的所述任务管理服务对所述任务进行处理的具体过程包括:
根据所述广播刷新所述任务列表;
读取所述任务列表中各所述任务的所述执行者ID;
判断所述执行者ID是否与所述节点ID一致;
若是,则根据对应的所述任务信息执行所述任务;
通过回调更新任务执行进度至所述任务的进度字段中,并在所述任务执行完成后删除对应的所述任务信息。
优选地,还包括:
接收所述目标节点发送的更新所述任务列表的提示信息,以用于通过所述任务分配节点更新所述任务列表。
为解决上述技术问题,本申请还提供一种任务分配装置,包括:
第一创建模块,用于在分布式存储集群中创建任务记录对象,以记录表征卷操作请求的任务的信息;
第二创建模块,用于创建各节点对应的任务管理服务;
选取模块,用于根据所述任务记录对象在各所述节点中选取任务分配节点;
判断模块,用于根据所述任务记录对象和所述任务分配节点判断是否接收到所述任务;若是,触发分配模块;
所述分配模块,用于通过所述任务分配节点分配所述任务至目标节点,以用于所述目标节点通过对应的所述任务管理服务对所述任务进行处理。
为解决上述技术问题,本申请还提供一种任务分配设备,包括:
存储器,用于存储计算机程序;
处理器,用于执行所述计算机程序时实现上述的任务分配方法的步骤。
为解决上述技术问题,本申请还提供一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现上述的任务分配方法的步骤。
本申请所提供的任务分配方法,通过在分布式存储集群中创建任务记录对象,以记录表征卷操作请求的任务的信息;创建各节点对应的任务管理服务;根据任务记录对象在各节点中选取任务分配节点;根据任务记录对象和任务分配节点判断是否接收到任务;若是,通过任务分配节点分配任务至目标节点,以用于目标节点通过对应的任务管理服务对任务进行处理。由此可知,上述方案通过在分布式存储集群中创建任务记录对象记录任务,并在全部节点中选取任务分配节点用于任务分配;当接收到任务时,由任务分配节点将任务分配至存储集群中其他节点进行处理,避免了卷管理类操作集中在管理节点堆积执行,节省了节点资源,提高了分布式存储集群的整体稳定性。
此外,本申请实施例还提供了一种任务分配装置、设备及介质,效果同上。
附图说明
为了更清楚地说明本申请实施例,下面将对实施例中所需要使用的附图做简单的介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本申请实施例提供的一种任务分配方法的流程图;
图2为本申请实施例提供的一种任务分配装置的示意图;
图3为本申请实施例提供的一种任务分配设备的示意图。
具体实施方式
下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创造性劳动前提下,所获得的所有其他实施例,都属于本申请保护范围。
本申请的核心是提供一种任务分配方法、装置、设备及介质。
为了使本技术领域的人员更好地理解本申请方案,下面结合附图和具体实施方式对本申请作进一步的详细说明。
图1为本申请实施例提供的一种任务分配方法的流程图。如图1所示,方法包括:
S10:在分布式存储集群中创建任务记录对象,以记录表征卷操作请求的任务的信息。
在具体实施中,首先在分布式存储集群中创建任务记录对象(Task_obj)。可以理解的是,该对象用于记录任务的各项信息,包括但不限于任务类型、操作目标(源卷、目的卷)、执行者ID等信息。每当分布式存储集群接收到卷操作请求,都应向任务记录对象中添加该任务的相关信息。
S11:创建各节点对应的任务管理服务。
进一步地,创建各节点对应的任务管理服务。可以理解的是,在分布式存储集群中存在多个节点,各节点均可应用于不同任务场景下的数据处理。而在具体实施中,各节点对于任务的处理主要由各自的任务管理服务实现。
S12:根据任务记录对象在各节点中选取任务分配节点。
为了避免分布式存储***的大量的卷管理类操作集中在管理节点堆积执行,在本实施例中根据任务记录对象在各节点中选取任务分配节点(leader)。
需要注意的是,任务分配节点是分布式存储集群全部节点中的一个节点,其主要作用是将分布式存储集群接收到的卷操作请求的任务分配至集群中其余节点中处理。本实施例中对于任务分配节点的具体选取方式不做限制,可直接在集群中各节点中选取,还可通过票选或接收选取请求的方式选取,根据具体的实施情况而定。
S13:根据任务记录对象和任务分配节点判断是否接收到任务;若是,进入步骤S14。
S14:通过任务分配节点分配任务至目标节点,以用于目标节点通过对应的任务管理服务对任务进行处理。
进一步地,根据任务记录对象和任务分配节点判断是否接收到任务。可以理解的是,由于任务记录对象用于记录任务信息,任务分配节点用于分配任务,则可通过根据任务记录对象和任务分配节点共同对是否接收到任务进行判断。本实施例中对于判断是否接收到任务的具体过程不做限制,根据具体的实施情况而定。
当确认接收到任务后,通过任务分配节点分配任务至目标节点,以用于目标节点通过对应的任务管理服务对任务进行处理。需要注意的是,本实施例对于任务分配节点对任务的具体分配方式不做限制,可直接分配至指定的目标节点,还可根据任务的相关信息进行分配,还可根据其余节点的当前状态进行分配,根据具体的实施情况而定。目标节点在分配到任务后,通过对应的任务管理服务对任务进行处理。
本实施例中,通过在分布式存储集群中创建任务记录对象,以记录表征卷操作请求的任务的信息;创建各节点对应的任务管理服务;根据任务记录对象在各节点中选取任务分配节点;根据任务记录对象和任务分配节点判断是否接收到任务;若是,通过任务分配节点分配任务至目标节点,以用于目标节点通过对应的任务管理服务对任务进行处理。由此可知,上述方案通过在分布式存储集群中创建任务记录对象记录任务,并在全部节点中选取任务分配节点用于任务分配;当接收到任务时,由任务分配节点将任务分配至存储集群中其他节点进行处理,避免了卷管理类操作集中在管理节点堆积执行,节省了节点资源,提高了分布式存储集群的整体稳定性。
在上述实施例的基础上,作为一种优选的实施例,在创建各节点对应的任务管理服务之后,在根据任务记录对象在各节点中选取任务分配节点之前,还包括:
通过各任务管理服务向任务记录对象注册对应的各节点的节点ID。
可以理解的是,为了使任务分配节点能够将任务分配至其余节点,则需要使任务分配节点获知各其余节点的信息。
具体地,在创建各节点对应的任务管理服务之后,通过各节点的任务管理服务向任务记录对象Task_obj注册对应的各节点的节点ID,通过存储用于处理任务的各节点的信息,便于后续的任务分配。
在上述实施例的基础上,作为一种优选的实施例,根据任务记录对象在各节点中选取任务分配节点包括:
基于任务记录对象创建分布式锁;
接收各节点通过对应的任务管理服务对分布式锁的申请;
分别判断各节点是否申请到分布式锁;
若是,则申请到分布式锁的节点为任务分配节点。
为了实现任务分配节点的选取,作为一种优选的实施例,本实施例中,首先在任务记录对象Task_obj上创建一个分布式锁;进一步所有节点通过各自的任务管理服务去申请该锁;任务记录对象接收各节点对分布式锁的申请,并分别判断各节点是否申请到分布式锁;申请到并持有该分布式锁的节点即为任务分配节点leader。
需要注意的是,本实施例中对于各节点申请到分布式锁的判定方式不做限制,可根据接收到各申请的时间顺序确定,还可通过票选的方式确定,根据具体的实施情况而定。
本实施例中,通过基于任务记录对象创建分布式锁;接收各节点通过对应的任务管理服务对分布式锁的申请;分别判断各节点是否申请到分布式锁;若是,则申请到分布式锁的节点为任务分配节点,实现了任务分配节点的选取。
在上述实施例的基础上,作为一种优选的实施例,根据任务记录对象和任务分配节点判断是否接收到任务包括:
通过任务分配节点定时读取任务记录对象中的任务;
判断读取到的任务是否与任务列表中现有的任务相同;
若否,则确认接收到任务,获取任务的任务信息;其中,任务信息包括任务类型、源卷信息、目的卷信息和执行者ID;
设置任务的任务ID并添加至任务信息中;
将任务信息写入任务记录对象中,进入通过任务分配节点分配任务至目标节点的步骤。
在具体实施中,任务分配节点leader定时读取任务记录对象中的任务,并判断读取到的任务是否与任务列表中现有的任务相同。可以理解的是,本实施例中的任务列表是用于存储分布式存储集群中现有的任务信息的列表;比较该列表中的任务与任务记录对象中的任务,当读取到的任务记录对象的任务与任务列表中的现有任务不同时,即出现了新的任务。
进一步地,当确认接受到了任务,获取任务的任务信息。本实施例中任务信息具体包括任务类型、源卷信息、目的卷信息和执行者ID。同时设置任务的任务ID并添加至任务信息中,并将全部任务信息以结构体的形式写入任务记录对象中,最后通过任务分配节点分配任务至目标节点。需要注意的是,在具体实施中任务ID可具体设置为一个随机分配的通用唯一识别码(Universally Unique Identifier,UUID),以对任务进行标识。
此外,本实施例中对于任务分配节点定时读取任务记录对象中的任务的定时时间不做限制,根据具体的实施情况而定。
本实施例中,通过任务分配节点定时读取任务记录对象中的任务;判断读取到的任务是否与任务列表中现有的任务相同;若否,则确认接收到任务,获取任务的任务信息;其中,任务信息包括任务类型、源卷信息、目的卷信息和执行者ID;设置任务的任务ID并添加至任务信息中;将任务信息写入任务记录对象中,进入通过任务分配节点分配任务至目标节点的步骤,实现了是否接收到任务的判断,同时对任务信息进行设置,以便于后续的任务处理。
在上述实施例的基础上,作为一种优选的实施例,通过任务分配节点分配任务至目标节点包括:
通过一致性哈希算法计算任务的任务ID,以将任务分配至目标节点;
将目标节点的节点ID写入任务的执行者ID的字段;
通过广播通知各节点刷新对应的任务列表。
为实现任务分配节点对目标节点的任务分配,作为一种优选的实施例,在本实施例中通过一致性哈希算法计算任务的任务ID,以将任务分配至目标节点。
一致性哈希(Consistent hashing)算法是一种特殊的哈希算法,目的是解决分布式缓存的问题。例如在移除或者添加一个服务器时,能够尽可能小地改变已存在的服务请求与处理请求服务器之间的映射关系。因此通过一致性哈希算法计算任务的任务ID实现的任务分配能够实现任务分配的负载均衡,避免将多个任务分配至同一个节点,从而提高整个分布式存储***的任务处理效率。
进一步将目标节点的节点ID写入该任务的任务信息中执行者ID的字段,并通过广播通知各节点刷新对应的任务列表,从而使得其他节点能够通过任务列表得知,目前该任务是由目标节点在处理。
本实施例中,通过一致性哈希算法计算任务的任务ID,以将任务分配至目标节点;将目标节点的节点ID写入任务的执行者ID的字段;通过广播通知各节点刷新对应的任务列表,实现了任务的分配。
在上述实施例的基础上,作为一种优选的实施例,目标节点通过对应的任务管理服务对任务进行处理的具体过程包括:
根据广播刷新任务列表;
读取任务列表中各任务的执行者ID;
判断执行者ID是否与节点ID一致;
若是,则根据对应的任务信息执行任务;
通过回调更新任务执行进度至任务的进度字段中,并在任务执行完成后删除对应的任务信息。
作为一种优选的实施例,当目标节点接收到广播后,根据广播刷新自身任务列表。读取列表中每个任务的执行者ID,并与自身节点ID进行比对。若执行者ID与自身节点ID一致,则根据任务的任务信息执行对应任务。
为实现任务执行进度的直观展示,在具体实施中,通过回调的形式更新任务执行进度至任务的进度字段中,能够通过目标节点的任务列表查看任务的执行情况。此外,当任务执行完毕之后,删除对应的任务信息,以释放任务列表的存储资源。
本实施例中,根据广播刷新任务列表;读取任务列表中各任务的执行者ID;判断执行者ID是否与节点ID一致;若是,则根据对应的任务信息执行任务;通过回调更新任务执行进度至任务的进度字段中,并在任务执行完成后删除对应的任务信息。实现了任务的处理,同时实现了任务执行进度的展示。
在上述实施例的基础上,作为一种优选的实施例,还包括:
接收目标节点发送的更新任务列表的提示信息,以用于通过任务分配节点更新任务列表。
最后当任务处理完成之后,为了实现任务分配节点对于任务处理状态的更新,作为一种优选的实施例,接收目标节点发送的更新任务列表的提示信息,任务分配节点进一步根据提示信息更新任务列表,从而实现了执行完成后任务信息的清除,释放了存储空间。
在上述实施例中,对于任务分配方法进行了详细描述,本申请还提供任务分配装置对应的实施例。
图2为本申请实施例提供的一种任务分配装置的示意图。如图2所示,任务分配装置包括:
第一创建模块10,用于在分布式存储集群中创建任务记录对象,以记录表征卷操作请求的任务的信息。
第二创建模块11,用于创建各节点对应的任务管理服务。
选取模块12,用于根据任务记录对象在各节点中选取任务分配节点。
判断模块13,用于根据任务记录对象和任务分配节点判断是否接收到任务;若是,触发分配模块14;
分配模块14,用于通过任务分配节点分配任务至目标节点,以用于目标节点通过对应的任务管理服务对任务进行处理。
本实施例中,任务分配装置包括第一创建模块、第二创建模块、选取模块、判断模块和分配模块。通过在分布式存储集群中创建任务记录对象,以记录表征卷操作请求的任务的信息;创建各节点对应的任务管理服务;根据任务记录对象在各节点中选取任务分配节点;根据任务记录对象和任务分配节点判断是否接收到任务;若是,通过任务分配节点分配任务至目标节点,以用于目标节点通过对应的任务管理服务对任务进行处理。由此可知,上述方案通过在分布式存储集群中创建任务记录对象记录任务,并在全部节点中选取任务分配节点用于任务分配;当接收到任务时,由任务分配节点将任务分配至存储集群中其他节点进行处理,避免了卷管理类操作集中在管理节点堆积执行,节省了节点资源,提高了分布式存储集群的整体稳定性。
图3为本申请实施例提供的一种任务分配设备的示意图。如图3所示,任务分配设备包括:
存储器20,用于存储计算机程序。
处理器21,用于执行计算机程序时实现如上述实施例中所提到的任务分配方法的步骤。
本实施例提供的任务分配设备可以包括但不限于智能手机、平板电脑、笔记本电脑或台式电脑等。
其中,处理器21可以包括一个或多个处理核心,比如4核心处理器、8核心处理器等。处理器21可以采用数字信号处理器(Digital Signal Processor,DSP)、现场可编程门阵列(Field-Programmable Gate Array,FPGA)、可编程逻辑阵列(Programmable LogicArray,PLA)中的至少一种硬件形式来实现。处理器21也可以包括主处理器和协处理器,主处理器是用于对在唤醒状态下的数据进行处理的处理器,也称中央处理器(CentralProcessing Unit,CPU);协处理器是用于对在待机状态下的数据进行处理的低功耗处理器。在一些实施例中,处理器21可以在集成有图形处理器(Graphics Processing Unit,GPU),GPU用于负责显示屏所需要显示的内容的渲染和绘制。一些实施例中,处理器21还可以包括人工智能(Artificial Intelligence,AI)处理器,该AI处理器用于处理有关机器学习的计算操作。
存储器20可以包括一个或多个计算机可读存储介质,该计算机可读存储介质可以是非暂态的。存储器20还可包括高速随机存取存储器,以及非易失性存储器,比如一个或多个磁盘存储设备、闪存存储设备。本实施例中,存储器20至少用于存储以下计算机程序201,其中,该计算机程序被处理器21加载并执行之后,能够实现前述任一实施例公开的任务分配方法的相关步骤。另外,存储器20所存储的资源还可以包括操作***202和数据203等,存储方式可以是短暂存储或者永久存储。其中,操作***202可以包括Windows、Unix、Linux等。数据203可以包括但不限于任务分配方法涉及到的数据。
在一些实施例中,任务分配设备还可包括有显示屏22、输入输出接口23、通信接口24、电源25以及通信总线26。
本领域技术人员可以理解,图3中示出的结构并不构成对任务分配设备的限定,可以包括比图示更多或更少的组件。
本实施例中,任务分配设备包括存储器和处理器。存储器用于存储计算机程序;处理器用于执行计算机程序时实现如上述实施例中所提到的任务分配方法的步骤。通过在分布式存储集群中创建任务记录对象,以记录表征卷操作请求的任务的信息;创建各节点对应的任务管理服务;根据任务记录对象在各节点中选取任务分配节点;根据任务记录对象和任务分配节点判断是否接收到任务;若是,通过任务分配节点分配任务至目标节点,以用于目标节点通过对应的任务管理服务对任务进行处理。由此可知,上述方案通过在分布式存储集群中创建任务记录对象记录任务,并在全部节点中选取任务分配节点用于任务分配;当接收到任务时,由任务分配节点将任务分配至存储集群中其他节点进行处理,避免了卷管理类操作集中在管理节点堆积执行,节省了节点资源,提高了分布式存储集群的整体稳定性。
最后,本申请还提供一种计算机可读存储介质对应的实施例。计算机可读存储介质上存储有计算机程序,计算机程序被处理器执行时实现如上述方法实施例中记载的步骤。
可以理解的是,如果上述实施例中的方法以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,执行本申请各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(Read-Only Memory,ROM)、随机存取存储器(Random Access Memory,RAM)、磁碟或者光盘等各种可以存储程序代码的介质。
本实施例中,计算机可读存储介质上存储有计算机程序,计算机程序被处理器执行时实现如上述方法实施例中记载的步骤。通过在分布式存储集群中创建任务记录对象,以记录表征卷操作请求的任务的信息;创建各节点对应的任务管理服务;根据任务记录对象在各节点中选取任务分配节点;根据任务记录对象和任务分配节点判断是否接收到任务;若是,通过任务分配节点分配任务至目标节点,以用于目标节点通过对应的任务管理服务对任务进行处理。由此可知,上述方案通过在分布式存储集群中创建任务记录对象记录任务,并在全部节点中选取任务分配节点用于任务分配;当接收到任务时,由任务分配节点将任务分配至存储集群中其他节点进行处理,避免了卷管理类操作集中在管理节点堆积执行,节省了节点资源,提高了分布式存储集群的整体稳定性。
以上对本申请所提供的一种任务分配方法、装置、设备及介质进行了详细介绍。说明书中各个实施例采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似部分互相参见即可。对于实施例公开的装置而言,由于其与实施例公开的方法相对应,所以描述的比较简单,相关之处参见方法部分说明即可。应当指出,对于本技术领域的普通技术人员来说,在不脱离本申请原理的前提下,还可以对本申请进行若干改进和修饰,这些改进和修饰也落入本申请权利要求的保护范围内。
还需要说明的是,在本说明书中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。

Claims (10)

1.一种任务分配方法,其特征在于,包括:
在分布式存储集群中创建任务记录对象,以记录表征卷操作请求的任务的信息;
创建各节点对应的任务管理服务;
根据所述任务记录对象在各所述节点中选取任务分配节点;
根据所述任务记录对象和所述任务分配节点判断是否接收到所述任务;
若是,通过所述任务分配节点分配所述任务至目标节点,以用于所述目标节点通过对应的所述任务管理服务对所述任务进行处理。
2.根据权利要求1所述的任务分配方法,其特征在于,在所述创建各节点对应的任务管理服务之后,在所述根据所述任务记录对象在各所述节点中选取任务分配节点之前,还包括:
通过各所述任务管理服务向所述任务记录对象注册对应的各所述节点的节点ID。
3.根据权利要求1所述的任务分配方法,其特征在于,所述根据所述任务记录对象在各所述节点中选取任务分配节点包括:
基于所述任务记录对象创建分布式锁;
接收各所述节点通过对应的所述任务管理服务对所述分布式锁的申请;
分别判断各所述节点是否申请到所述分布式锁;
若是,则申请到所述分布式锁的所述节点为所述任务分配节点。
4.根据权利要求2所述的任务分配方法,其特征在于,所述根据所述任务记录对象和所述任务分配节点判断是否接收到所述任务包括:
通过所述任务分配节点定时读取所述任务记录对象中的所述任务;
判断读取到的所述任务是否与任务列表中现有的所述任务相同;
若否,则确认接收到所述任务,获取所述任务的任务信息;其中,所述任务信息包括任务类型、源卷信息、目的卷信息和执行者ID;
设置所述任务的任务ID并添加至所述任务信息中;
将所述任务信息写入所述任务记录对象中,进入所述通过所述任务分配节点分配所述任务至目标节点的步骤。
5.根据权利要求4所述的任务分配方法,其特征在于,所述通过所述任务分配节点分配所述任务至目标节点包括:
通过一致性哈希算法计算所述任务的所述任务ID,以将所述任务分配至所述目标节点;
将所述目标节点的所述节点ID写入所述任务的所述执行者ID的字段;
通过广播通知各所述节点刷新对应的所述任务列表。
6.根据权利要求5所述的任务分配方法,其特征在于,所述目标节点通过对应的所述任务管理服务对所述任务进行处理的具体过程包括:
根据所述广播刷新所述任务列表;
读取所述任务列表中各所述任务的所述执行者ID;
判断所述执行者ID是否与所述节点ID一致;
若是,则根据对应的所述任务信息执行所述任务;
通过回调更新任务执行进度至所述任务的进度字段中,并在所述任务执行完成后删除对应的所述任务信息。
7.根据权利要求4至6任意一项所述的任务分配方法,其特征在于,还包括:
接收所述目标节点发送的更新所述任务列表的提示信息,以用于通过所述任务分配节点更新所述任务列表。
8.一种任务分配装置,其特征在于,包括:
第一创建模块,用于在分布式存储集群中创建任务记录对象,以记录表征卷操作请求的任务的信息;
第二创建模块,用于创建各节点对应的任务管理服务;
选取模块,用于根据所述任务记录对象在各所述节点中选取任务分配节点;
判断模块,用于根据所述任务记录对象和所述任务分配节点判断是否接收到所述任务;若是,触发分配模块;
所述分配模块,用于通过所述任务分配节点分配所述任务至目标节点,以用于所述目标节点通过对应的所述任务管理服务对所述任务进行处理。
9.一种任务分配设备,其特征在于,包括:
存储器,用于存储计算机程序;
处理器,用于执行所述计算机程序时实现如权利要求1至7任一项所述的任务分配方法的步骤。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如权利要求1至7任一项所述的任务分配方法的步骤。
CN202211292977.6A 2022-10-21 2022-10-21 一种任务分配方法、装置、设备及介质 Pending CN115599300A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202211292977.6A CN115599300A (zh) 2022-10-21 2022-10-21 一种任务分配方法、装置、设备及介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202211292977.6A CN115599300A (zh) 2022-10-21 2022-10-21 一种任务分配方法、装置、设备及介质

Publications (1)

Publication Number Publication Date
CN115599300A true CN115599300A (zh) 2023-01-13

Family

ID=84848812

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202211292977.6A Pending CN115599300A (zh) 2022-10-21 2022-10-21 一种任务分配方法、装置、设备及介质

Country Status (1)

Country Link
CN (1) CN115599300A (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN115934006A (zh) * 2023-03-14 2023-04-07 北京志凌海纳科技有限公司 Io接入点和数据处理任务管理方法、装置、设备和介质
CN117591039A (zh) * 2024-01-18 2024-02-23 济南浪潮数据技术有限公司 分布式存储方法、***、设备及介质

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN115934006A (zh) * 2023-03-14 2023-04-07 北京志凌海纳科技有限公司 Io接入点和数据处理任务管理方法、装置、设备和介质
CN117591039A (zh) * 2024-01-18 2024-02-23 济南浪潮数据技术有限公司 分布式存储方法、***、设备及介质

Similar Documents

Publication Publication Date Title
US11586673B2 (en) Data writing and reading method and apparatus, and cloud storage system
CN115599300A (zh) 一种任务分配方法、装置、设备及介质
CN107968810B (zh) 一种服务器集群的资源调度方法、装置和***
US9385989B2 (en) Method and apparatus for managing MAC address generation for virtualized environments
CN110941481A (zh) 资源调度方法、装置及***
CN106844055B (zh) 一种任务的执行方法和装置
US11068317B2 (en) Information processing system and resource allocation method
CN105874426A (zh) 一种***调用命令的批处理方法及装置
CN111078628A (zh) 一种多盘并发数据迁移方法、***、装置及可读存储介质
CN107977275B (zh) 基于消息队列的任务处理方法及相关设备
CN111143053A (zh) 一种定时任务的调度方法、服务器以及存储装置
CN104182295A (zh) 一种数据备份方法及装置
CN113535087A (zh) 数据迁移过程中的数据处理方法、服务器及存储***
CN106571935B (zh) 一种资源调度的方法与设备
CN109788013B (zh) 分布式***中作业资源分配方法、装置及设备
CN108205559B (zh) 一种数据管理方法及其设备
CN112433669A (zh) 一种分布式存储卷在线迁移的方法、***、设备及介质
CN112631994A (zh) 数据迁移方法及***
CN112363980A (zh) 一种分布式***的数据处理方法及装置
CN111198756A (zh) 一种kubernetes集群的应用调度方法及装置
CN111475277A (zh) 一种资源分配方法、***、设备及机器可读存储介质
CN111491040B (zh) 一种ip分配方法以及ip分配装置
CN114721876A (zh) 一种数据备份方法、装置、介质
CN113742065A (zh) 一种基于kubernetes容器集群的分布式强化学习方法及装置
CN112817766B (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