CN115858124A - 一种基板管理系统控制方法、装置、介质 - Google Patents
一种基板管理系统控制方法、装置、介质 Download PDFInfo
- Publication number
- CN115858124A CN115858124A CN202211624963.XA CN202211624963A CN115858124A CN 115858124 A CN115858124 A CN 115858124A CN 202211624963 A CN202211624963 A CN 202211624963A CN 115858124 A CN115858124 A CN 115858124A
- Authority
- CN
- China
- Prior art keywords
- thread
- task
- request
- annular
- queue
- 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
- 238000000034 method Methods 0.000 title claims abstract description 64
- 239000000758 substrate Substances 0.000 title description 13
- 238000004590 computer program Methods 0.000 claims description 12
- 230000006870 function Effects 0.000 claims description 10
- 238000004140 cleaning Methods 0.000 claims description 3
- 230000004622 sleep time Effects 0.000 claims description 2
- 230000008569 process Effects 0.000 description 18
- 238000012545 processing Methods 0.000 description 7
- 230000009471 action Effects 0.000 description 4
- 238000010586 diagram Methods 0.000 description 4
- 238000005516 engineering process Methods 0.000 description 4
- 230000004044 response Effects 0.000 description 3
- 238000004891 communication Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000013473 artificial intelligence Methods 0.000 description 1
- 238000009530 blood pressure measurement Methods 0.000 description 1
- 238000004422 calculation algorithm Methods 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000010801 machine learning Methods 0.000 description 1
- 230000005055 memory storage Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000000750 progressive effect Effects 0.000 description 1
- 230000009467 reduction Effects 0.000 description 1
- 238000009877 rendering Methods 0.000 description 1
- 230000036578 sleeping time Effects 0.000 description 1
- 238000009662 stress testing Methods 0.000 description 1
- 230000001052 transient effect Effects 0.000 description 1
- 239000002699 waste material Substances 0.000 description 1
Images
Landscapes
- Debugging And Monitoring (AREA)
Abstract
本申请涉及服务器领域,公开了一种基板管理系统控制方法、装置、介质,包括获取系统发送的请求任务,确定线程池中用于执行请求任务的目标线程,以便于通过目标线程执行任务以控制服务器正常工作。将请求任务放入与目标线程对应的环形任务队列中,防止单个任务队列同时被多个线程操作导致系统故障,以便于目标线程从环形任务队列中获取并执行请求任务。由此可见,本申请所提供的技术方案包括将请求任务放入与目标线程对应的环形队列中,防止多个线程访问一个队列的情况出现,以在不加线程锁的前提下防止多个线程访问同一队列导致的线程冲突。同时,各工作线程的分别与不同的工作队列相对应,进一步提高了基板管理系统的性能。
Description
技术领域
本申请涉及服务器领域,特别是涉及一种基板管理系统控制方法、装置、介质。
背景技术
服务器基板管理控制器(Baseboard Management Controller,BMC)用于对服务器平台的工作状态进行监测和控制,以确定服务器平台中各设备的工作状态。由于服务器平台中传感器的类型较多,为了保证及时响应,需要在BMC内部使用多线程技术对任务请求进行处理。目前多线程技术通常需要预先建立包含多个线程的线程池,通过线程池提供统一的任务接口,从而执行BMC进程所发送的任务请求。
目前常用的线程池技术中的线程多为共享工作队列,即:线程池中的主线程将任务请求放入工作队列中,线程池中的各工作线程从工作队列中取出任务请求并执行。由于主线程和各工作线程均共用一个工作队列,为了防止多个线程之间同时对工作队列进行操作导致不可预知的问题,需要在线程池中加入线程锁。但由于BMC的硬件性能较差,而线程锁会占用大量计算资源,导致程序工作效率降低,影响BMC的正常工作。
由此可见,如何提供一种更加高效的基板管理系统控制方法,以防止线程锁影响基板管理系统的工作效率,是本领域技术人员亟需解决的问题。
发明内容
本申请的目的是提供一种基板管理系统控制方法、装置、介质,以防止线程锁影响BMC的工作效率,从而提高基板管理系统的工作效率。
为了解决上述技术问题,本申请提供了一种基板管理系统控制方法,包括:
获取系统发送的请求任务;
确定线程池中用于执行所述请求任务的目标线程;
将所述请求任务放入与所述目标线程对应的环形任务队列中,以便于所述目标线程从所述环形任务队列中获取并执行所述请求任务。
优选的,所述确定线程池中用于执行所述请求任务的目标线程的步骤后,还包括:
判断所述目标线程是否具有所述环形任务队列;
若具有所述环形任务队列,则执行所述将所述请求任务放入与所述目标线程对应的环形任务队列中的步骤;
若不具有所述环形任务队列,则为所述目标线程创建所述环形任务队列。
优选的,所述为所述目标线程创建所述环形任务队列包括:
获取所述环形任务队列的数据结构,并初始化所述环形任务队列;
根据所述环形任务队列的数据结构实现所述环形任务队列的入队函数和出队函数。
优选的,所述确定线程池中用于执行所述请求任务的目标线程包括:
获取各所述环形任务队列中的请求任务数;
确定所述请求任务数最小的所述环形任务队列所对应的线程为所述目标线程。
优选的,所述将所述请求任务放入与所述目标线程对应的环形任务队列中的步骤后,还包括:
当检测到所述线程池中的工作者线程的数量改变时,获取与各线程对应的所述环形任务队列中的请求任务数;
根据所述请求任务数对各请求任务进行重新分配,以保证各所述环形任务队列中的请求任务均衡。
优选的,所述根据所述请求任务数对各请求任务进行重新分配包括:
根据各所述请求任务数确定待重分配线程;
将所述待重分配线程放入所述请求任务数最小的工作者线程的环形工作队列中。
优选的,还包括:当检测到所述线程池中的休眠线程的休眠时间大于预设休眠周期时,清理与所述休眠线程对应的环形任务队列。
为了解决上述技术问题,本申请还提供了一种基板管理系统控制装置,包括:
获取模块,用于获取系统发送的请求任务;
确定模块,用于确定线程池中用于执行所述请求任务的目标线程;
执行模块,用于将所述请求任务放入与所述目标线程对应的环形任务队列中,以便于所述目标线程从所述环形任务队列中获取并执行所述请求任务。
为了解决上述技术问题,本申请还提供了一种基板管理系统控制装置,包括存储器,用于存储计算机程序;
处理器,用于执行所述计算机程序时实现所述的基板管理系统控制方法的步骤。
为了解决上述技术问题,本申请还提供了一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现所述的基板管理系统控制方法的步骤。
本申请提供了一种基板管理系统控制方法,该方法包括获取系统发送的请求任务,确定线程池中用于执行请求任务的目标线程,以便于通过目标线程执行任务以控制服务器正常工作。将请求任务放入与目标线程对应的环形任务队列中,防止单个任务队列同时被多个线程操作导致系统故障,以便于目标线程从环形任务队列中获取并执行请求任务。由此可见,本申请所提供的技术方案包括将请求任务放入与目标线程对应的环形队列中,防止多个线程访问一个队列的情况出现,以在不加线程锁的前提下防止多个线程访问同一队列导致的线程冲突。同时,各工作线程的分别与不同的工作队列相对应,防止各工作线程的冲突,进一步提高了基板管理系统的性能。
此外,本申请还提供了一种基板管理系统控制装置、介质,与上述方法对应,效果同上。
附图说明
为了更清楚地说明本申请实施例,下面将对实施例中所需要使用的附图做简单的介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本申请实施例所提供的一种基板管理系统控制方法的流程图;
图2为本申请实施例所提供的一种基板管理系统控制装置的结构图;
图3为本申请实施例所提供的另一种基板管理系统控制装置的结构图。
具体实施方式
下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创造性劳动前提下,所获得的所有其他实施例,都属于本申请保护范围。
本申请的核心是提供一种基板管理系统控制方法、装置、介质,以防止线程锁影响BMC的工作效率,从而提高基板管理系统的工作效率。
为了便于理解,下面将对本发明的技术方案所适用的硬件架构进行介绍。在具体实施中,启动服务器,服务器的基板管理控制器(Baseboard Management Controller,BMC)加载基本输入输出系统
(BasicInputOutputSystem,BIOS)信息,其中BIOS信息包括了中央处理器(Central Processing Unit,CPU)相关信息、硬盘信息、内存信息、时钟信息等。BMC内部需要大量的线程来完成基板信息检测任务,也就是通常所说的多线程技术。多线程技术通常实现的方式有两种:当请求任务来到时进行创建线程,对每一个任务单独创建一个线程,当任务请求量大而密时,大量而频繁的创建线程和销毁线程的开销将会拖慢任务响应时间,降低了系统性能;或采用线程池技术,线程池统一任务接口,通过提高请求响应时间来提升系统整体性能。其核心就是节省创建和销毁线程的开销,解决大量请求与有限资源的矛盾。因此高效的线程池对BMC的性能提升显得尤为重要。为了解决这一问题,目前的线程池通常包括主线程和工作线程,其中,各工作线程具有相应的工作队列,主线程将任务放入工作队列中。但这种情况下,主线程和工作线程共享工作队列,为了防止工作队列发送读写冲突,需要加入线程锁,但线程锁会占用大量的计算资源,影响线程池的正常工作。为了解决这一问题,本申请提供了一种基板管理系统控制方法,该方法包括获取系统发送的请求任务,确定线程池中用于执行请求任务的目标线程,以便于通过目标线程执行任务以控制服务器正常工作。将请求任务放入与目标线程对应的环形任务队列中,防止单个任务队列同时被多个线程操作导致系统故障,以便于目标线程从环形任务队列中获取并执行请求任务。由此可见,本申请所提供的技术方案包括将请求任务放入与目标线程对应的环形队列中,防止多个线程访问一个队列的情况出现,以在不加线程锁的前提下防止多个线程访问同一队列导致的线程冲突。同时,各工作线程的分别与不同的工作队列相对应,防止各工作线程的冲突,进一步提高了基板管理系统的性能。
在具体实施中,为了评估基板管理系统性能,还需要对基板进行压力测试。部署一台带有BMC板卡的服务器,将实现程序交叉编译后形成一个新镜像,刷到BMC卡中。刷新完成后,登录BMC系统。外部使用压测脚本模拟高并发请求,查看BMC整体系统性能状态,从而判断基板管理系统的性能。
为了使本技术领域的人员更好地理解本申请方案,下面结合附图和具体实施方式对本申请作进一步的详细说明。
图1为本申请实施例所提供的一种基板管理系统控制方法的流程图,如图1所示,该方法包括:
S10:获取系统发送的请求任务。
S11:确定线程池中用于执行请求任务的目标线程。
S12:将请求任务放入与目标线程对应的环形任务队列中,以便于目标线程从环形任务队列中获取并执行请求任务。
在具体实施中,本申请所提供的技术方案应用于基板管理控制系统,获取系统发送的请求任务即为基板管理控制系统获取各基板管理控制进程发送的请求任务,确定线程池中用于执行请求任务的目标线程,以执行请求任务。其中,请求任务通常包括:CPU相关任务、存储设备相关任务、时钟相关任务等。需要注意的是,当不存在线程池时,还需要根据用户的指令或默认指令创建线程池。具体的,当接收到线程池创建指令时,获取线程池参数(包括最大线程数(MAX_THR)、最小线程数(MIN_THR)等),并调用标准接口创建线程池。
可以理解的是,为了保证各线程任务数量的动态平衡,在检测到线程池中的工作者线程的数量改变时,可以根据各请求任务数确定待重分配线程,并将待重分配线程放入请求任务数最小的工作者线程的环形工作队列中,从而充分发挥基板管理系统线程池的计算性能。
具体的,当获取到各基板管理控制进程发送的请求任务时,将请求任务保存至主进程所对应的任务队列中。因为与主进程所对应的任务队列仅能够有主进程进行操作,不涉及多个进程的冲突问题,因此,主进程所对应的任务队列可以为普通队列,也可以为环形队列。主进程从任务队列中取出任务请求后,将任务请求放入目标进程所对应的环形队列中,以便于目标进程执行任务请求。需要注意的是,目标进程的选取遵循均衡分配原则(least_load),通过获取各环形任务队列中的请求任务数;确定请求任务数最小的环形任务队列所对应的线程为目标线程。
目前的线程池中多为多个线程共用一个任务队列,由主线程实现任务的分配,但这一方式容易导致主线程与任务线程、任务线程间的相互冲突,需要设置线程锁以保证线程池的正常运行。为了解决这一问题,本申请中为线程池中的每个线程均创建一个工作队列,这个工作队列为一个环形队列,避免主线程放入任务和工作线程取出任务的竞争问题。这种环形队列只有主线程进行入队操作,工作线程进行出队操作,由于只有一个入队线程和一个出队线程,所以两个线程可以并发操作,而不需要任何加锁行为,就可以保证线程安全。在具体实施中,环形队列的具体实现方式包括:首先定义环形队列的数据结构,包含如下属性:buffer(一个存放数据的缓存,存放队列成员)、size(缓存大小)、in(入队指针,指向队列头)、out(出对指针,指向队列尾);队列初始化,为队列申请内存空间,并初始化队列的各个参数;实现入队函数接口,包括查询剩余空间,拷贝数据进内存,更新in指针等;实现出队接口函数,包括查询剩余空间,更新out指针等,与入队函数类似。
本实施例提供了一种基板管理系统控制方法,该方法包括获取系统发送的请求任务,确定线程池中用于执行请求任务的目标线程,以便于通过目标线程执行任务以控制服务器正常工作。将请求任务放入与目标线程对应的环形任务队列中,防止单个任务队列同时被多个线程操作导致系统故障,以便于目标线程从环形任务队列中获取并执行请求任务。由此可见,本申请所提供的技术方案包括将请求任务放入与目标线程对应的环形队列中,防止多个线程访问一个队列的情况出现,以在不加线程锁的前提下防止多个线程访问同一队列导致的线程冲突。同时,各工作线程的分别与不同的工作队列相对应,防止各工作线程的冲突,进一步提高了基板管理系统的性能。
在具体实施中,线程池中各线程所对应的环形队列可以为创建线程池的过程中创建的,也可以为在将休眠线程唤醒时创建的。考虑到线程池中线程数量较多,若同时为线程池中的各个线程创建环形队列需要花费大量的时间,因此,在本实施例中,选择在唤醒休眠线程时为线程创建环形队列。在上述实施例的基础上,确定线程池中用于执行请求任务的目标线程的步骤后,还包括:判断目标线程是否具有环形任务队列;若具有环形任务队列,则执行将请求任务放入与目标线程对应的环形任务队列中的步骤;若不具有环形任务队列,则为目标线程创建环形任务队列。
在具体实施中,为目标线程创建环形任务队列包括:
获取环形任务队列的数据结构,并初始化环形任务队列;
根据环形任务队列的数据结构实现环形任务队列的入队函数和出队函数。
在具体实施中,由于各线程均具有与之相对应的环形队列,为了保证各线程的负载均衡,提高基板管理系统的性能,需要尽可能的使各线程所对应的环形队列中的任务数量相同。作为优选的实施例,确定线程池中用于执行请求任务的目标线程包括:获取各环形任务队列中的请求任务数;确定请求任务数最小的环形任务队列所对应的线程为目标线程。
在本实施例中,通过将请求任务数最小的环形任务队列所对应的线程为目标线程,以尽可能的使各线程所对应的环形队列中的任务数量相同,从而实现各线程的负载均衡,提高基板管理系统的性能。
可以理解的是,各任务请求的类型不同,各线程执行任务请求所需要的时间也不相同。因此,在基板系统执行任务请求的过程中,各环形队列中的任务数量始终动态变化,导致各线程的负载不均衡。为了解决这一问题,在上述实施例的基础上,将请求任务放入与目标线程对应的环形任务队列中的步骤后,还包括:当检测到线程池中的工作者线程的数量改变时,获取与各线程对应的环形任务队列中的请求任务数;根据请求任务数对各请求任务进行重新分配,以保证各环形任务队列中的请求任务均衡。
进一步的,根据请求任务数对各请求任务进行重新分配包括:
根据各请求任务数确定待重分配线程;
将待重分配线程放入请求任务数最小的工作者线程的环形工作队列中。
在具体实施中,主线程放入任务时,选择有最少工作的工作线程对应的队列。在线程的动态减少后,原先线程上未能执行完的任务只需要由主线程再次根据任务调度算法重新分配至其他存活的工作者线程队列中即可。
在本实施例中,通过在检测到线程池中的工作者线程的数量改变时,根据各请求任务数确定待重分配线程,并将待重分配线程放入请求任务数最小的工作者线程的环形工作队列中,以保证各线程任务数量的动态平衡,从而充分发挥基板管理系统线程池的计算性能。
在具体实施中,为了保证线程池能够满足高业务压力下的正常工作,线程池中存在的线程的数量远远大于日常需要的数量。为了减少计算资源的浪费,需要使闲置的线程休眠。
在上述实施例的基础上,本实施例所提供的基板管理系统控制方法还包括:当检测到线程池中的休眠线程的休眠时间大于预设休眠周期时,清理与休眠线程对应的环形任务队列。
在上述实施例中,对于基板管理系统控制方法进行了详细描述,本申请还提供基板管理系统控制装置对应的实施例。需要说明的是,本申请从两个角度对装置部分的实施例进行描述,一种是基于功能模块的角度,另一种是基于硬件的角度。
由于装置部分的实施例与方法部分的实施例相互对应,因此装置部分的实施例请参见方法部分的实施例的描述,这里暂不赘述。
图2为本申请实施例所提供的一种基板管理系统控制装置的结构图,如图2所示,该基板管理系统控制装置包括:
获取模块10,用于获取系统发送的请求任务;
确定模块11,用于确定线程池中用于执行请求任务的目标线程;
执行模块12,用于将请求任务放入与目标线程对应的环形任务队列中,以便于目标线程从环形任务队列中获取并执行请求任务。
本实施例提供了一种基板管理系统控制装置,该装置包括获取系统发送的请求任务,确定线程池中用于执行请求任务的目标线程,以便于通过目标线程执行任务以控制服务器正常工作。将请求任务放入与目标线程对应的环形任务队列中,防止单个任务队列同时被多个线程操作导致系统故障,以便于目标线程从环形任务队列中获取并执行请求任务。由此可见,本申请所提供的技术方案包括将请求任务放入与目标线程对应的环形队列中,防止多个线程访问一个队列的情况出现,以在不加线程锁的前提下防止多个线程访问同一队列导致的线程冲突。同时,各工作线程的分别与不同的工作队列相对应,防止各工作线程的冲突,进一步提高了基板管理系统的性能。
图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所述的基板管理系统控制方法,其特征在于,所述确定线程池中用于执行所述请求任务的目标线程的步骤后,还包括:
判断所述目标线程是否具有所述环形任务队列;
若具有所述环形任务队列,则执行所述将所述请求任务放入与所述目标线程对应的环形任务队列中的步骤;
若不具有所述环形任务队列,则为所述目标线程创建所述环形任务队列。
3.根据权利要求2所述的基板管理系统控制方法,其特征在于,所述为所述目标线程创建所述环形任务队列包括:
获取所述环形任务队列的数据结构,并初始化所述环形任务队列;
根据所述环形任务队列的数据结构实现所述环形任务队列的入队函数和出队函数。
4.根据权利要求1所述的基板管理系统控制方法,其特征在于,所述确定线程池中用于执行所述请求任务的目标线程包括:
获取各所述环形任务队列中的请求任务数;
确定所述请求任务数最小的所述环形任务队列所对应的线程为所述目标线程。
5.根据权利要求1所述的基板管理系统控制方法,其特征在于,所述将所述请求任务放入与所述目标线程对应的环形任务队列中的步骤后,还包括:
当检测到所述线程池中的工作者线程的数量改变时,获取与各线程对应的所述环形任务队列中的请求任务数;
根据所述请求任务数对各请求任务进行重新分配,以保证各所述环形任务队列中的请求任务均衡。
6.根据权利要求5所述的基板管理系统控制方法,其特征在于,所述根据所述请求任务数对各请求任务进行重新分配包括:
根据各所述请求任务数确定待重分配线程;
将所述待重分配线程放入所述请求任务数最小的工作者线程的环形工作队列中。
7.根据权利要求1至6任一项所述的基板管理系统控制方法,其特征在于,还包括:当检测到所述线程池中的休眠线程的休眠时间大于预设休眠周期时,清理与所述休眠线程对应的环形任务队列。
8.一种基板管理系统控制装置,其特征在于,包括:
获取模块,用于获取系统发送的请求任务;
确定模块,用于确定线程池中用于执行所述请求任务的目标线程;
执行模块,用于将所述请求任务放入与所述目标线程对应的环形任务队列中,以便于所述目标线程从所述环形任务队列中获取并执行所述请求任务。
9.一种基板管理系统控制装置,其特征在于,包括存储器,用于存储计算机程序;
处理器,用于执行所述计算机程序时实现如权利要求1至7任一项所述的基板管理系统控制的步骤。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如权利要求1至7任一项所述的基板管理系统控制的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211624963.XA CN115858124A (zh) | 2022-12-16 | 2022-12-16 | 一种基板管理系统控制方法、装置、介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202211624963.XA CN115858124A (zh) | 2022-12-16 | 2022-12-16 | 一种基板管理系统控制方法、装置、介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN115858124A true CN115858124A (zh) | 2023-03-28 |
Family
ID=85673721
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202211624963.XA Pending CN115858124A (zh) | 2022-12-16 | 2022-12-16 | 一种基板管理系统控制方法、装置、介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115858124A (zh) |
-
2022
- 2022-12-16 CN CN202211624963.XA patent/CN115858124A/zh active Pending
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10649935B2 (en) | Deferred inter-processor interrupts | |
US20210208935A1 (en) | Method for Scheduling Multi-Core Processor, Terminal, and Storage Medium | |
US9201693B2 (en) | Quota-based resource management | |
US8904386B2 (en) | Running a plurality of instances of an application | |
US9465734B1 (en) | Coalition based memory management | |
US11907762B2 (en) | Resource conservation for containerized systems | |
US9411649B2 (en) | Resource allocation method | |
KR101839646B1 (ko) | 접속형 대기 상태를 프로세스의 일시 정지 및/또는 조절 기법 | |
CN111831437B (zh) | 设备管理方法、装置、存储介质及电子设备 | |
CN111459622B (zh) | 调度虚拟cpu的方法、装置、计算机设备和存储介质 | |
CN114968567A (zh) | 用于分配计算节点的计算资源的方法、装置和介质 | |
WO2023044877A1 (zh) | 一种渲染任务处理方法、装置、电子设备及存储介质 | |
CN110795323A (zh) | 负载统计方法、装置、存储介质及电子设备 | |
US9229716B2 (en) | Time-based task priority boost management using boost register values | |
CN111831436B (zh) | Io请求的调度方法、装置、存储介质及电子设备 | |
CN113032154B (zh) | 一种虚拟cpu的调度方法、装置、电子设备及存储介质 | |
CN115858124A (zh) | 一种基板管理系统控制方法、装置、介质 | |
US9933832B2 (en) | Systems and methods for modifying power states in a virtual environment | |
CN114721876A (zh) | 一种数据备份方法、装置、介质 | |
CN110333899B (zh) | 数据处理方法、装置和存储介质 | |
CN115033459A (zh) | 一种cpu使用率监测方法、装置及存储介质 | |
CN111831412B (zh) | 中断处理方法、装置、存储介质及电子设备 | |
EP3679468A1 (en) | Controller event queues | |
CN116893893B (zh) | 一种虚拟机调度方法、装置、电子设备及存储介质 | |
US11112999B2 (en) | Optimizing I/O latency by software stack latency reduction in a cooperative thread processing model |
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 |