CN110471763B - 基于共享对象池的调度方法、系统、介质及电子设备 - Google Patents
基于共享对象池的调度方法、系统、介质及电子设备 Download PDFInfo
- Publication number
- CN110471763B CN110471763B CN201910690391.7A CN201910690391A CN110471763B CN 110471763 B CN110471763 B CN 110471763B CN 201910690391 A CN201910690391 A CN 201910690391A CN 110471763 B CN110471763 B CN 110471763B
- Authority
- CN
- China
- Prior art keywords
- pool
- target
- pools
- object pool
- returned
- 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.)
- Active
Links
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/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5011—Allocation 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
- G06F9/5016—Allocation 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 the resource being the memory
-
- 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/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5027—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Stored Programmes (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本发明揭示了一种基于共享对象池的调度方法、系统、介质及电子设备。所述方法包括:接收对象获取请求,其中,该对象获取请求用于获取目标类型的对象;根据对象获取请求,判断所有对象池中是否存在请求队列为空的目标对象池;如果存在目标对象池,检测目标对象池中是否存放有目标类型的对象;如果存放有目标类型的对象,触发对象派发线程通过接口从目标对象池获取目标类型的对象。此方法下,能够提高资源利用率。
Description
技术领域
本发明涉及云存储技术领域,特别涉及一种基于共享对象池的调度方法、系统、介质及电子设备。
背景技术
目前,对象池在互联网技术中得到了广泛的应用。通过引入对象池可以有效减少从头创建每个对象的系统开销。在实际应用中,如果需要激活对象时可以直接从对象池中提取;如果停用对象时,将对象放回对象池中,对象池可以继续等待下一个使用对象的请求。
然而,目前对于对象池中对象的调用主要针对的是具体业务,即每一种对象池中的对象仅适用于某一种功能,例如连接池只能操作对于网络连接的功能。可见,在现有技术中,各个对象池的使用均是独立的,并不存在共享的情况,因此使得处理器内存资源得不到有效利用,资源利用率低。
发明内容
为了解决相关技术中存在的处理器内存资源得不到有效利用、资源利用率低的技术问题,本发明提供了一种基于共享对象池的调度方法、系统、介质及电子设备。
本发明实施例第一方面公开了一种基于共享对象池的调度方法,所述方法包括:
接收对象获取请求,所述对象获取请求用于获取目标类型的对象;
根据所述对象获取请求,判断所有对象池中是否存在请求队列为空的目标对象池;
如果存在所述目标对象池,检测所述目标对象池中是否存放有所述目标类型的对象;
如果存放有所述目标类型的对象,触发对象派发线程通过接口从所述目标对象池获取所述目标类型的对象。
作为一种可选的实施方式,在本发明实施例第一方面中,如果未存放有所述目标类型的对象,所述方法还包括:
判断所述目标对象池中已创建的对象数目是否小于预设数量阈值;
如果所述已创建的对象数目小于所述预设数量阈值,在所述目标对象池中创建新的对象;其中,所述新的对象的类型为所述目标类型;
如果所述已创建的对象数目不小于所述预设数量阈值,检测是否存在待返回所述目标对象池的待返回对象;所述待返回对象的类型为所述目标类型;
如果存在所述待返回对象,触发所述对象派发线程通过接口在所述待返回对象返回所述目标对象池时获取所述待返回对象。
作为一种可选的实施方式,在本发明实施例第一方面中,所述在所述目标对象池中创建新的对象,包括:
按照预设的对象配置参数创建新的对象;
按照存储规则将所述新的对象存储到所述目标对象池中;其中,所述新的对象的对象标识与所述目标对象池的对象池标识相匹配。
作为一种可选的实施方式,在本发明实施例第一方面中,如果存在所述待返回对象,所述方法还包括:
判断所述待返回对象是否具有重复使用特性;
如果所述待返回对象具有所述重复使用特性,执行所述的触发所述对象派发线程通过接口在所述待返回对象返回所述目标对象池时获取所述待返回对象。
作为一种可选的实施方式,在本发明实施例第一方面中,所述判断所有对象池中是否存在请求队列为空的目标对象池,包括:
判断所有对象池中是否存在请求队列为空的空闲对象池;
如果存在所述空闲对象池,获取所述空闲对象池的空闲个数;
计算所述空闲个数与预设的最小空闲个数之间的差值;
判断所述差值是否大于预设差值阈值;
如果所述差值大于所述预设差值阈值,获取每个所述空闲对象池的空闲时长;
关闭所述空闲时长长于预设时长阈值的空闲对象池,得到剩余空闲对象池;
从所述剩余空闲对象池中确定目标对象池。
作为一种可选的实施方式,在本发明实施例第一方面中,所述从所述剩余空闲对象池中确定目标对象池,包括:
确定当前位于各个所述剩余空闲对象池的对象数量;
将所有所述剩余空闲对象池中所述对象数量最多的剩余空闲对象池确定为目标对象池。
作为一种可选的实施方式,在本发明实施例第一方面中,如果不存在所述目标对象池,所述方法还包括:
从存放所述目标类型的其他对象池中确定出备选对象池;其中,所述其他对象池为所述所有对象池中除所述目标对象池以外的对象池;
将所述对象获取请求加入所述备选对象池的请求队列;
基于每个获取请求对应的处理优先级,对所述备选对象池的请求队列中所有的获取请求进行重新排序,并按照重新排序后的请求队列对所述获取请求进行处理。
本发明实施例第二方面公开了一种基于共享对象池的调度系统,包括:
接收单元,用于接收对象获取请求,所述对象获取请求用于获取目标类型的对象;
判断单元,用于根据所述对象获取请求,判断所有对象池中是否存在请求队列为空的目标对象池;
检测单元,用于在所述判断单元判断出存在所述目标对象池时,检测所述目标对象池中是否存放有所述目标类型的对象;
获取单元,用于在所述检测单元检测出存放有所述目标类型的对象时,触发对象派发线程通过接口从所述目标对象池获取所述目标类型的对象。
本发明实施例第三方面公开一种计算机可读存储介质,其存储计算机程序,其中,所述计算机程序使得计算机执行本发明实施例第一方面公开的一种基于共享对象池的调度方法。
本发明实施例第四方面公开一种电子设备,所述电子设备包括:
处理器;
存储器,所述存储器上存储有计算机可读指令,所述计算机可读指令被所述处理器执行时,实现如前所述的方法。
本发明的实施例提供的技术方案可以包括以下有益效果:
本发明所提供的基于共享对象池的调度方法包括如下步骤,接收对象获取请求,其中,该对象获取请求用于获取目标类型的对象;根据对象获取请求,判断所有对象池中是否存在请求队列为空的目标对象池;如果存在目标对象池,检测目标对象池中是否存放有目标类型的对象;如果存放有目标类型的对象,触发对象派发线程通过接口从目标对象池获取目标类型的对象。
此方法下,能够在接收到对象获取请求之后,在各个对象池中找到请求队列为空的目标对象池,并检测目标对象池中是否存在目标类型的对象,如果存在,则获取该目标类型的对象。可见,本方法使得各个对象池的对象得到共享,因此提高了资源利用率。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性的,并不能限制本发明。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本发明的实施例,并于说明书一起用于解释本发明的原理。
图1是根据一示例性实施例示出的一种装置的示意图;
图2是根据一示例性实施例示出的一种基于共享对象池的调度方法的流程图;
图3是根据另一示例性实施例示出的一种基于共享对象池的调度方法的流程图;
图4是根据一示例性实施例示出的一种基于共享对象池的调度系统的框图;
图5是根据一示例性实施例示出的另一种基于共享对象池的调度系统的框图。
具体实施方式
这里将详细地对示例性实施例执行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本发明相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本发明的一些方面相一致的装置和方法的例子。
图1是根据一示例性实施例示出的一种装置的示意图。装置100可以是电子设备。如图1所示,装置100可以包括以下一个或多个组件:处理组件102,存储器104,电源组件106,多媒体组件108,音频组件110,传感器组件114以及通信组件116。
处理组件102通常控制装置100的整体操作,诸如与显示,电话呼叫,数据通信,相机操作以及记录操作相关联的操作等。处理组件102可以包括一个或多个处理器118来执行指令,以完成下述的方法的全部或部分步骤。此外,处理组件102可以包括一个或多个模块,用于便于处理组件102和其他组件之间的交互。例如,处理组件102可以包括多媒体模块,用于以方便多媒体组件108和处理组件102之间的交互。
存储器104被配置为存储各种类型的数据以支持在装置100的操作。这些数据的示例包括用于在装置100上操作的任何应用程序或方法的指令。存储器104可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(Static RandomAccess Memory,简称SRAM),电可擦除可编程只读存储器(Electrically ErasableProgrammable Read-Only Memory,简称EEPROM),可擦除可编程只读存储器(ErasableProgrammable Read Only Memory,简称EPROM),可编程只读存储器(Programmable Red-Only Memory,简称PROM),只读存储器(Read-Only Memory,简称ROM),磁存储器,快闪存储器,磁盘或光盘。存储器104中还存储有一个或多个模块,用于该一个或多个模块被配置成由该一个或多个处理器118执行,以完成如下所示方法中的全部或者部分步骤。
电源组件106为装置100的各种组件提供电力。电源组件106可以包括电源管理系统,一个或多个电源,及其他与为装置100生成、管理和分配电力相关联的组件。
多媒体组件108包括在所述装置100和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(Liquid Crystal Display,简称LCD)和触摸面板。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。屏幕还可以包括有机电致发光显示器(Organic Light Emitting Display,简称OLED)。
音频组件110被配置为输出和/或输入音频信号。例如,音频组件110包括一个麦克风(Microphone,简称MIC),当装置100处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器104或经由通信组件116发送。在一些实施例中,音频组件110还包括一个扬声器,用于输出音频信号。
传感器组件114包括一个或多个传感器,用于为装置100提供各个方面的状态评估。例如,传感器组件114可以检测到装置100的打开/关闭状态,组件的相对定位,传感器组件114还可以检测装置100或装置100一个组件的位置改变以及装置100的温度变化。在一些实施例中,该传感器组件114还可以包括磁传感器,压力传感器或温度传感器。
通信组件116被配置为便于装置100和其他设备之间有线或无线方式的通信。装置100可以接入基于通信标准的无线网络,如WiFi(Wireless-Fidelity,无线保真)。在一个示例性实施例中,通信组件116经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信组件116还包括近场通信(Near FieldCommunication,简称NFC)模块,用于以促进短程通信。例如,在NFC模块可基于射频识别(Radio Frequency Identification,简称RFID)技术,红外数据协会(Infrared DataAssociation,简称IrDA)技术,超宽带(Ultra Wideband,简称UWB)技术,蓝牙技术和其他技术来实现。
在示例性实施例中,装置100可以被一个或多个应用专用集成电路(ApplicationSpecific Integrated Circuit,简称ASIC)、数字信号处理器、数字信号处理设备、可编程逻辑器件、现场可编程门阵列、控制器、微控制器、微处理器或其他电子元件实现,用于执行下述方法。
图2是根据一示例性实施例示出的一种基于共享对象池的调度方法的流程图。如图2所示,此方法包括以下步骤。
步骤201,调度系统接收对象获取请求;其中,该对象获取请求用于获取目标类型的对象。
本发明实施例中,对象(Object)指的是面向对象程序设计中用来描述客观事物的程序单位,以连接池(连接池也属于对象池的一种)为例,连接池中的对象指的是连接。对象池(Object Pool)的工作原理是:对象池可以充当保存对象的“容器”,将用过的对象保存起来,等下一次需要这种对象时,再拿出来重复使用,从而在一定程度上减少频繁创建对象所造成的开销。当一个线程需要一个对象的时候,它需要从对象池中借出一个对象,当使用完毕后需要将该对象还回对象池;此外,对象获取请求还可以由任意客户端发出,本发明实施例不做限定。
步骤202,调度系统根据对象获取请求,判断所有对象池中是否存在请求队列为空的目标对象池,如果存在目标对象池,触发执行步骤203;如果未存在该目标对象池,结束本流程。
本发明实施例中,如果对象池的请求队列为空,说明该对象池中存放的对象当前未处于被使用状态。可见,本发明实施例,能够在所有对象池中查找请求队列为空的目标对象池,以此提高对象的获取效率。
作为一种可选的实施方式,调度系统根据对象获取请求,判断所有对象池中是否存在请求队列为空的目标对象池,可以包括:
根据对象获取请求,判断所有对象池中是否存在请求队列为空的空闲对象池;如果存在空闲对象池,获取空闲对象池的空闲个数;计算空闲个数与预设的最小空闲个数之间的差值;判断差值是否大于预设差值阈值;如果差值大于预设差值阈值,获取每个空闲对象池的空闲时长;关闭空闲时长长于预设时长阈值的空闲对象池,得到剩余空闲对象池;从剩余空闲对象池中确定目标对象池。
进一步可选的,调度系统从剩余空闲对象池中确定目标对象池,可以包括:
确定当前位于各个剩余空闲对象池的对象数量;
将所有剩余空闲对象池中对象数量最多的剩余空闲对象池确定为目标对象池。
作为另一种可选的实施方式,如果不存在目标对象池,调度系统还可以执行以下步骤:
从存放目标类型的其他对象池中确定出备选对象池;其中,其他对象池为所有对象池中除目标对象池以外的对象池;
将对象获取请求加入备选对象池的请求队列;
基于每个获取请求对应的处理优先级,对备选对象池的请求队列中所有的获取请求进行重新排序,并按照重新排序后的请求队列对获取请求进行处理。
本发明实施例中,可选的,处理优先级可以划分为高、中、低三级,优选地,本方案中用于获取目标类型的对象的对象获取请求可以对应“高”这一级的处理优先级。可见,实施本发明实施例,能够利用每个获取请求对应的处理优先级对请求队列中的所有获取请求进行重新排序,以使备选对象池按照重新排序后的请求队列对获取请求进行处理,实现了获取请求的有序处理,并且利用处理优先级对各个获取请求进行排序,满足了不同类型的获取请求的处理需求。
步骤203,调度系统检测目标对象池中是否存放有目标类型的对象,如果存放有目标类型的对象,触发执行步骤204;如果未存放有该目标类型的对象,结束本流程。
本发明实施例中,对象池中可以存放有一个或多个对象;进一步可选的,同一对象池中可以存放有不同类型的对象,本发明实施例不做限定。
本发明实施例中,可以采用遍历目标对象池的方式检测目标对象池中是否存放有目标类型的对象。具体地,遍历目标对象池的方式可以是JAVA中的CAS操作,本发明实施例不做限定。进一步地,当遍历目标对象池找到目标类型的对象时,可以将该目标类型的对象的状态改为被使用(占用)状态,同时结束遍历操作,能够避免造成不必要的CPU资源的开销。
步骤204,调度系统触发对象派发线程通过接口从目标对象池获取目标类型的对象。
本发明实施例中,线程(thread)是程序中一个单一的顺序控制流程,是执行一个程序命令的单元。对象池用于在线程处理过程中缓存对象,它设有接口,对象派发线程通过对象池接口从对象池中获取对象。
可见,实施图2所描述的基于共享对象池的调度方法,能够基于客户端的对象获取请求,在所有对象池中对目标类型的对象进行适当调度,提高了资源的利用效率;以及,实现了获取请求的有序处理,并且利用处理优先级对各个获取请求进行排序,满足了不同类型的获取请求的处理需求;此外,当遍历目标对象池找到目标类型的对象时,可以将该目标类型的对象的状态改为被使用(占用)状态,同时结束遍历操作,能够避免造成不必要的CPU资源的开销。
图3是根据另一示例性实施例示出的一种基于共享对象池的调度方法的流程图。如图3所示,该基于共享对象池的调度方法可以包括以下步骤:
本发明实施例中,该基于共享对象池的调度方法还包括步骤301~303,针对步骤301~303的描述,请参照上述实施例一中针对步骤201~203的详细描述,本发明实施例不再赘述。其中,在步骤303中,如果存放有目标类型的对象,可以触发执行步骤304;如果未存放有目标类型的对象,可以触发执行步骤305。
步骤304,调度系统触发对象派发线程通过接口从目标对象池获取目标类型的对象。
步骤305,调度系统判断目标对象池中已创建的对象数目是否小于预设数量阈值;如果已创建的对象数目小于预设数量阈值,触发执行步骤306;如果已创建的对象数目不小于预设数量阈值,触发执行步骤307。
本发明实施例中,由于对象池的容量大小有限,如果目标对象池中已创建的对象数目不小于预设数量阈值,说明目标对象池此时的容量已经接近饱和。
可选的,调度系统在判断出目标对象池中已创建的对象数目不小于预设数量阈值之后,还可以执行以下步骤:
利用爬山算法,构造自适应的对象池大小的动态调整方案,使得该目标对象池具有自适应的动态调整能力。
本方案中,构造自适应的对象池大小的动态调整方案,具体来说,可以首先预定义目标对象池容量的最小值、调整时间间隔;在预定义的时间间隔内测量对象池内请求队列的执行时长,并针对对象池中各对象的提取(获取)次数进行统计,统计执行时长小于预设执行时长的对象提取方案,将此类方案确定为健康方案,并以此作为下一时间间隔内对象池容量的评估依据。若评估得到的当前方案不符合健康方案的要求,利用爬山算法记录的若干历史时间间隔的评估数据对对象池容量进行择优调整;若评估得到的当前方案符合健康方案的要求,则不需要调整。其中,爬山算法是一种择优算法,具体来说,就是算法迭代时,每次用临近解空间内的更优解取代前解。可见,实施本方案,能够构造一个自适应的对象池动态调整方案,实现了对象池容量的动态调整。
步骤306,调度系统在目标对象池中创建新的对象,并触发对象派发线程通过接口获取该新的对象;其中,该新的对象的类型为目标类型。
本发明实施例中,目标对象池中已创建的对象数目小于预设数量阈值,说明当前并未达到目标对象池的最大容量,因此,可以在目标对象池中创建新的对象,以满足客户端不断增长的需求。
作为一种可选的实施方式,调度系统在目标对象池中创建新的对象,可以包括:
按照预设的对象配置参数创建新的对象;
按照存储规则将新的对象存储到目标对象池中;其中,新的对象的对象标识与目标对象池的对象池标识相匹配。
本发明实施例中,可选的,预设的存储规则可以是:每个对象对应有唯一的对象标识,每个对象池也对应有唯一的对象池标识;并且该存储规则用于规定对象标识与对象池标识之间的对应(匹配)关系。
可见,本发明实施例,可以根据对象标识与对象池标识之间的对应关系,将对象存放到指定的对象池中,实现了对象的合理存储。
步骤307,调度系统检测是否存在待返回目标对象池的待返回对象;如果存在待返回对象,触发执行步骤308;如果不存在待返回对象,结束本流程;其中,待返回对象的类型为目标类型。
作为一种可选的实施方式,如果存在上述待返回对象,调度系统还可以执行以下步骤:
判断待返回对象是否具有重复使用特性;
如果待返回对象具有重复使用特性,触发执行步骤307。
本发明实施例中,调度系统在检测到任意客户端返回的待返回对象时,首先应该检查该待返回对象是否能够重复使用,即该待返回对象是否具有重复使用特性;如果该待返回对象具有重复使用特性,可以将该待返回对象放入与其对象标识相匹配的对象池标识所对应的对象池中;或者可以直接将该待返回对象借出给其他存在使用需求的客户端。反之,如果该待返回对象不具有重复使用特性,那么,调度系统可以舍弃该待返回对象。
步骤308,调度系统触发对象派发线程通过接口在待返回对象返回目标对象池时获取待返回对象。
可见,实施图3所描述的基于共享对象池的调度方法,能够基于客户端的对象获取请求,在所有对象池中对目标类型的对象进行适当调度,提高了资源的利用效率;以及,实现了获取请求的有序处理,并且利用处理优先级对各个获取请求进行排序,满足了不同类型的获取请求的处理需求;以及,当遍历目标对象池找到目标类型的对象时,可以将该目标类型的对象的状态改为被使用(占用)状态,同时结束遍历操作,能够避免造成不必要的CPU资源的开销;以及,能够构造一个自适应的对象池动态调整方案,实现了对象池容量的动态调整;以及,可以根据对象标识与对象池标识之间的对应关系,将对象存放到指定的对象池中,实现了对象的合理存储。
以下是本发明的装置实施例。
图4是根据一示例性实施例示出的一种基于共享对象池的调度系统的框图。如图4所示,该系统包括:
接收单元401,用于接收对象获取请求,并将该对象获取请求提供给判断单元402,其中,该对象获取请求用于获取目标类型的对象。
第一判断单元402,用于根据对象获取请求,判断所有对象池中是否存在请求队列为空的目标对象池,并将判断结果提供给检测单元403。
检测单元403,用于在上述第一判断单元402判断出存在目标对象池时,检测目标对象池中是否存放有目标类型的对象,并将检测结果提供给获取单元404。
本发明实施例中,对象池中可以存放有一个或多个对象;进一步可选的,同一对象池中可以存放有不同类型的对象,本发明实施例不做限定。
本发明实施例中,检测单元403可以采用遍历目标对象池的方式检测目标对象池中是否存放有目标类型的对象。具体地,遍历目标对象池的方式可以是JAVA中的CAS操作,本发明实施例不做限定。进一步地,当遍历目标对象池找到目标类型的对象时,可以将该目标类型的对象的状态改为被使用(占用)状态,同时结束遍历操作,能够避免造成不必要的CPU资源的开销。
第一获取单元404,用于在上述检测单元403检测出存放有目标类型的对象时,触发对象派发线程通过接口从目标对象池获取目标类型的对象。
可见,实施图4所描述的系统,能够基于客户端的对象获取请求,在所有对象池中对目标类型的对象进行适当调度,提高了资源的利用效率;以及,实现了获取请求的有序处理,并且利用处理优先级对各个获取请求进行排序,满足了不同类型的获取请求的处理需求;此外,当遍历目标对象池找到目标类型的对象时,可以将该目标类型的对象的状态改为被使用(占用)状态,同时结束遍历操作,能够避免造成不必要的CPU资源的开销。
请参阅图5,图5根据一示例性实施例示出的另一种调度系统的框图,其中,图5所示的系统是由图4所示的系统进一步进行优化得到的。与图4所示的系统相比较,图5所示的系统还包括:
第二判断单元405,用于在上述检测单元403检测出未存放有目标类型的对象时,判断目标对象池中已创建的对象数目是否小于预设数量阈值,并将判断结果提供给创建单元406。
创建单元406,用于在上述第二判断单元405判断出已创建的对象数目小于预设数量阈值时,在目标对象池中创建新的对象;其中,该新的对象的类型为目标类型。
上述检测单元403,还用于在上述第二判断单元405判断出已创建的对象数目不小于预设数量阈值时,检测是否存在待返回目标对象池的待返回对象,并将检测结果提供给第二获取单元407;其中,该待返回对象的类型为目标类型。
第二获取单元407,用于在上述检测单元403检测出存在待返回对象时,触发对象派发线程通过接口在待返回对象返回目标对象池时获取待返回对象。
作为一种可选的实施方式,如图5所示,上述创建单元406可以包括:
创建子单元4061,用于按照预设的对象配置参数创建新的对象,并将该新的对象提供给存储子单元4062。
存储子单元4062,用于按照存储规则将新的对象存储到目标对象池中;其中,该新的对象的对象标识与目标对象池的对象池标识相匹配。
本发明实施例中,可选的,预设的存储规则可以是:每个对象对应有唯一的对象标识,每个对象池也对应有唯一的对象池标识;并且该存储规则用于规定对象标识与对象池标识之间的对应(匹配)关系。
可见,本发明实施例,可以根据对象标识与对象池标识之间的对应关系,将对象存放到指定的对象池中,实现了对象的合理存储。
作为另一种可选的实施方式,如图5所示,上述第二判断单元405,还用于在上述检测单元403检测出存在待返回对象时,判断待返回对象是否具有重复使用特性,并将判断结果提供给第二获取单元407。
上述第二获取单元407,具体用于在上述第二判断单元405判断出待返回对象具有重复使用特性时,触发对象派发线程通过接口在待返回对象返回目标对象池时获取待返回对象。
作为又一种可选的实施方式,如图5所示,上述第一判断单元402,包括:
判断子单元4021,用于根据对象获取请求,判断所有对象池中是否存在请求队列为空的空闲对象池,并将判断结果提供给获取子单元4022。
获取子单元4022,用于在判断子单元4021判断出存在空闲对象池时,获取空闲对象池的空闲个数,并提供给计算子单元4023。
计算子单元4023,计算空闲个数与预设的最小空闲个数之间的差值,并将该差值结果提供给判断子单元4021。
上述判断子单元4021,还用于判断差值是否大于预设差值阈值,并将判断结果提供给获取子单元4022。
上述获取子单元4022,用于在上述判断子单元4021判断出差值大于预设差值阈值时,获取每个空闲对象池的空闲时长,并将空闲时长提供给关闭子单元4024。
关闭子单元4024,用于关闭空闲时长长于预设时长阈值的空闲对象池,得到剩余空闲对象池,并提供给确定子单元4025。
确定子单元4025,用于从剩余空闲对象池中确定目标对象池。
其中,可选的,确定子单元4025从剩余空闲对象池中确定目标对象池的方式具体可以为:
确定当前位于各个剩余空闲对象池的对象数量;
将所有剩余空闲对象池中对象数量最多的剩余空闲对象池确定为目标对象池。
作为又一种可选的实施方式,如图5所示,上述调度系统还可以包括:
确定单元408,用于在上述第一判断单元402判断出不存在目标对象池时,从存放目标类型的其他对象池中确定出备选对象池,并触发请求队列单元409启动;其中,其他对象池为所有对象池中除目标对象池以外的对象池。
请求队列单元409,用于将对象获取请求加入备选对象池的请求队列,并触发处理单元410启动。
处理单元410,用于基于每个获取请求对应的处理优先级,对备选对象池的请求队列中所有的获取请求进行重新排序,并按照重新排序后的请求队列对获取请求进行处理。
可见,实施图5所描述的系统,能够基于客户端的对象获取请求,在所有对象池中对目标类型的对象进行适当调度,提高了资源的利用效率;以及,实现了获取请求的有序处理,并且利用处理优先级对各个获取请求进行排序,满足了不同类型的获取请求的处理需求;以及,当遍历目标对象池找到目标类型的对象时,可以将该目标类型的对象的状态改为被使用(占用)状态,同时结束遍历操作,能够避免造成不必要的CPU资源的开销;以及,能够构造一个自适应的对象池动态调整方案,实现了对象池容量的动态调整;以及,可以根据对象标识与对象池标识之间的对应关系,将对象存放到指定的对象池中,实现了对象的合理存储。
本发明还提供一种电子设备,该电子设备包括:
处理器;
存储器,该存储器上存储有计算机可读指令,该计算机可读指令被处理器执行时,实现如前所示的性能测试方法。
在一示例性实施例中,本发明还提供一种计算机可读存储介质,其上存储有计算机程序,该计算机程序被处理器执行时,实现如前所示的基于共享对象池的调度方法。
应当理解的是,本发明并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围执行各种修改和改变。本发明的范围仅由所附的权利要求来限制。
Claims (10)
1.一种基于共享对象池的调度方法,其特征在于,所述方法包括:
接收对象获取请求,所述对象获取请求用于获取目标类型的对象;
根据所述对象获取请求,判断所有对象池中是否存在请求队列为空的目标对象池;
如果存在所述目标对象池,检测所述目标对象池中是否存放有所述目标类型的对象;
如果存放有所述目标类型的对象,触发对象派发线程通过接口从所述目标对象池获取所述目标类型的对象。
2.根据权利要求1所述的方法,其特征在于,如果未存放有所述目标类型的对象,所述方法还包括:
判断所述目标对象池中已创建的对象数目是否小于预设数量阈值;
如果所述已创建的对象数目小于所述预设数量阈值,在所述目标对象池中创建新的对象;其中,所述新的对象的类型为所述目标类型;
如果所述已创建的对象数目不小于所述预设数量阈值,检测是否存在待返回所述目标对象池的待返回对象;所述待返回对象的类型为所述目标类型;
如果存在所述待返回对象,触发所述对象派发线程通过接口在所述待返回对象返回所述目标对象池时获取所述待返回对象。
3.根据权利要求2所述的方法,其特征在于,所述在所述目标对象池中创建新的对象,包括:
按照预设的对象配置参数创建新的对象;
按照存储规则将所述新的对象存储到所述目标对象池中;其中,所述新的对象的对象标识与所述目标对象池的对象池标识相匹配。
4.根据权利要求2所述的方法,其特征在于,如果存在所述待返回对象,所述方法还包括:
判断所述待返回对象是否具有重复使用特性;
如果所述待返回对象具有所述重复使用特性,执行所述的触发所述对象派发线程通过接口在所述待返回对象返回所述目标对象池时获取所述待返回对象。
5.根据权利要求1所述的方法,其特征在于,所述根据所述对象获取请求,判断所有对象池中是否存在请求队列为空的目标对象池,包括:
根据所述对象获取请求,判断所有对象池中是否存在请求队列为空的空闲对象池;
如果存在所述空闲对象池,获取所述空闲对象池的空闲个数;
计算所述空闲个数与预设的最小空闲个数之间的差值;
判断所述差值是否大于预设差值阈值;
如果所述差值大于所述预设差值阈值,获取每个所述空闲对象池的空闲时长;
关闭所述空闲时长长于预设时长阈值的空闲对象池,得到剩余空闲对象池;
从所述剩余空闲对象池中确定目标对象池。
6.根据权利要求5所述的方法,其特征在于,所述从所述剩余空闲对象池中确定目标对象池,包括:
确定当前位于各个所述剩余空闲对象池的对象数量;
将所有所述剩余空闲对象池中所述对象数量最多的剩余空闲对象池确定为目标对象池。
7.根据权利要求1所述的方法,其特征在于,如果不存在所述目标对象池,所述方法还包括:
从存放所述目标类型的其他对象池中确定出备选对象池;其中,所述其他对象池为所述所有对象池中除所述目标对象池以外的对象池;
将所述对象获取请求加入所述备选对象池的请求队列;
基于每个获取请求对应的处理优先级,对所述备选对象池的请求队列中所有的获取请求进行重新排序,并按照重新排序后的请求队列对所述获取请求进行处理。
8.一种基于共享对象池的调度系统,其特征在于,包括:
接收单元,用于接收对象获取请求,所述对象获取请求用于获取目标类型的对象;
判断单元,用于根据所述对象获取请求,判断所有对象池中是否存在请求队列为空的目标对象池;
检测单元,用于在所述判断单元判断出存在所述目标对象池时,检测所述目标对象池中是否存放有所述目标类型的对象;
获取单元,用于在所述检测单元检测出存放有所述目标类型的对象时,触发对象派发线程通过接口从所述目标对象池获取所述目标类型的对象。
9.一种计算机可读存储介质,其特征在于,其存储计算机程序,所述计算机程序使得计算机执行权利要求1~7任一项所述的基于共享对象池的调度方法。
10.一种电子设备,包括存储器和处理器,所述存储器存储有计算机程序,其特征在于,所述处理器执行所述计算机程序时实现权利要求1~7中任一项所述的方法的步骤。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910690391.7A CN110471763B (zh) | 2019-07-29 | 2019-07-29 | 基于共享对象池的调度方法、系统、介质及电子设备 |
PCT/CN2019/118060 WO2021017304A1 (zh) | 2019-07-29 | 2019-11-13 | 基于共享对象池的调度方法、系统、电子设备及计算机可读存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910690391.7A CN110471763B (zh) | 2019-07-29 | 2019-07-29 | 基于共享对象池的调度方法、系统、介质及电子设备 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110471763A CN110471763A (zh) | 2019-11-19 |
CN110471763B true CN110471763B (zh) | 2023-07-25 |
Family
ID=68509029
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910690391.7A Active CN110471763B (zh) | 2019-07-29 | 2019-07-29 | 基于共享对象池的调度方法、系统、介质及电子设备 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN110471763B (zh) |
WO (1) | WO2021017304A1 (zh) |
Families Citing this family (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111273968A (zh) * | 2020-01-17 | 2020-06-12 | 上海米哈游天命科技有限公司 | 一种对象调用方法、装置、设备及介质 |
CN113449316B (zh) * | 2020-03-27 | 2023-07-18 | 武汉瓯越网视有限公司 | 一种程序的加密解密方法、装置和可读存储介质 |
CN111522645B (zh) * | 2020-04-29 | 2023-09-12 | 抖音视界有限公司 | 对象的处理方法、装置、电子设备及计算机可读存储介质 |
CN112181663A (zh) * | 2020-10-15 | 2021-01-05 | 新华三大数据技术有限公司 | 一种内存调度方法、装置及计算机设备 |
US11095745B1 (en) * | 2020-10-23 | 2021-08-17 | EMC IP Holding Company LLC | Cloud-based scheduling of data operations to an object storage using an operation pool |
CN114546665B (zh) * | 2022-04-22 | 2022-08-05 | 恒生电子股份有限公司 | 对象处理方法以及系统 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108228332A (zh) * | 2016-12-13 | 2018-06-29 | 北京嘀嘀无限科技发展有限公司 | 对象池访问方法及装置 |
CN109298901A (zh) * | 2018-08-29 | 2019-02-01 | 百度在线网络技术(北京)有限公司 | 对象处理方法、装置、设备、存储介质和车辆 |
CN109669739A (zh) * | 2017-10-16 | 2019-04-23 | 阿里巴巴集团控股有限公司 | 一种界面渲染方法、装置、终端设备和存储介质 |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100714693B1 (ko) * | 2005-06-07 | 2007-05-04 | 삼성전자주식회사 | 소프트웨어 모듈의 독립성을 보장하는 데이터베이스어플리케이션을 구현하는 시스템 및 방법 |
EP2363806A1 (en) * | 2010-03-03 | 2011-09-07 | Software AG | Connection handler and method for providing applications with heterogeneous connection objects |
CN109710259B (zh) * | 2018-12-28 | 2022-03-18 | 北京小米移动软件有限公司 | 一种数据处理方法、装置及存储介质 |
CN110046038A (zh) * | 2019-03-12 | 2019-07-23 | 平安普惠企业管理有限公司 | 一种基于线程池的任务处理方法及装置 |
-
2019
- 2019-07-29 CN CN201910690391.7A patent/CN110471763B/zh active Active
- 2019-11-13 WO PCT/CN2019/118060 patent/WO2021017304A1/zh active Application Filing
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108228332A (zh) * | 2016-12-13 | 2018-06-29 | 北京嘀嘀无限科技发展有限公司 | 对象池访问方法及装置 |
CN109669739A (zh) * | 2017-10-16 | 2019-04-23 | 阿里巴巴集团控股有限公司 | 一种界面渲染方法、装置、终端设备和存储介质 |
CN109298901A (zh) * | 2018-08-29 | 2019-02-01 | 百度在线网络技术(北京)有限公司 | 对象处理方法、装置、设备、存储介质和车辆 |
Also Published As
Publication number | Publication date |
---|---|
CN110471763A (zh) | 2019-11-19 |
WO2021017304A1 (zh) | 2021-02-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110471763B (zh) | 基于共享对象池的调度方法、系统、介质及电子设备 | |
CN107463403B (zh) | 进程控制方法、装置、存储介质以及电子设备 | |
CN109857551B (zh) | 基于云计算的服务资源的调度方法及装置、电子设备 | |
CN110162384B (zh) | 基于Redis分布式锁的超时时间动态调整方法及系统 | |
KR101706359B1 (ko) | 백그라운드 애플리케이션을 제어하기 위한 방법 및 장치 | |
CN111404836B (zh) | 数据传输控制方法、装置、控制中心、服务器及介质 | |
US10956316B2 (en) | Method and device for processing reclaimable memory pages, and storage medium | |
CN109509017B (zh) | 基于大数据分析的用户留存率预测方法及装置 | |
CN110659133B (zh) | 一种资源分配方法及分配装置、存储介质、电子设备 | |
US10698837B2 (en) | Memory processing method and device and storage medium | |
CN109697074A (zh) | 一种管理应用的方法和移动终端 | |
CN107479951A (zh) | 进程管控方法、装置、存储介质及电子设备 | |
CN110018900A (zh) | 内存处理方法和装置、电子设备、计算机可读存储介质 | |
CN106339260B (zh) | 基于Jenkins平台的任务分配方法及装置 | |
CN112269650A (zh) | 任务调度方法、装置、电子设备和存储介质 | |
WO2019024640A1 (zh) | 进程控制方法、装置、存储介质以及电子设备 | |
CN108701026A (zh) | 用于在存储器约束下管理进程的方法和装置 | |
CN114124593B (zh) | 多设备的调用方法、装置、控制终端和存储介质 | |
CN112486658B (zh) | 一种任务调度方法、装置和用于任务调度的装置 | |
CN111046040A (zh) | 确定索引的方法、装置、电子设备及存储介质 | |
CN109802994B (zh) | 一种基于内容分发网络的消息推送方法及系统 | |
CN108038050B (zh) | 性能调整方法、装置、存储介质及电子设备 | |
CN112363825A (zh) | 一种弹性伸缩方法及装置 | |
CN112997152B (zh) | 应用程序的优先级调整方法、装置、存储介质及电子设备 | |
CN108984294A (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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |