CN115168052A - 一种自适应内存回收控制方法、装置、终端及存储介质 - Google Patents
一种自适应内存回收控制方法、装置、终端及存储介质 Download PDFInfo
- Publication number
- CN115168052A CN115168052A CN202210909660.6A CN202210909660A CN115168052A CN 115168052 A CN115168052 A CN 115168052A CN 202210909660 A CN202210909660 A CN 202210909660A CN 115168052 A CN115168052 A CN 115168052A
- Authority
- CN
- China
- Prior art keywords
- memory
- recovery
- waterline
- rate
- difference
- 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
- 230000015654 memory Effects 0.000 title claims abstract description 269
- 238000011084 recovery Methods 0.000 title claims abstract description 242
- 238000000034 method Methods 0.000 title claims abstract description 62
- 238000012544 monitoring process Methods 0.000 claims abstract description 33
- 230000003044 adaptive effect Effects 0.000 claims description 37
- 238000004064 recycling Methods 0.000 claims description 36
- 239000000872 buffer Substances 0.000 abstract description 9
- 230000006399 behavior Effects 0.000 abstract description 4
- 230000008569 process Effects 0.000 description 17
- 230000007246 mechanism Effects 0.000 description 10
- 238000010586 diagram Methods 0.000 description 7
- 238000004891 communication Methods 0.000 description 6
- 230000009471 action Effects 0.000 description 4
- 230000008859 change Effects 0.000 description 4
- 230000004044 response Effects 0.000 description 4
- 230000008878 coupling Effects 0.000 description 3
- 238000010168 coupling process Methods 0.000 description 3
- 238000005859 coupling reaction Methods 0.000 description 3
- 230000000694 effects Effects 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 3
- 230000002159 abnormal effect Effects 0.000 description 2
- 230000006870 function Effects 0.000 description 2
- 238000012545 processing Methods 0.000 description 2
- 230000001960 triggered effect Effects 0.000 description 2
- XLYOFNOQVPJJNP-UHFFFAOYSA-N water Substances O XLYOFNOQVPJJNP-UHFFFAOYSA-N 0.000 description 2
- 238000011161 development Methods 0.000 description 1
- 238000002955 isolation Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000005457 optimization Methods 0.000 description 1
- 238000012827 research and development Methods 0.000 description 1
- 230000003068 static effect Effects 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/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
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/0223—User address space allocation, e.g. contiguous or non contiguous base addressing
- G06F12/023—Free address space management
- G06F12/0253—Garbage collection, i.e. reclamation of unreferenced memory
- G06F12/0269—Incremental or concurrent garbage collection, e.g. in real-time systems
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Software Systems (AREA)
- Memory System (AREA)
Abstract
本发明涉及内存回收领域,具体公开一种自适应内存回收控制方法、装置、终端及存储介质,监测预设时间间隔内是否发生直接回收操作;若发生直接回收操作,则启动异步回收进程;在异步回收进程中,根据内存消耗速率与回收速率的比值调整内存水线差值,且内存消耗速率与回收速率比值越大,内存水线差值越大;其中内存水线差值指高水线与低水线之间的差值。本发明通过对系统下发生直接回收行为的监控,提前启动异步回收,增加异步回收时间;通过动态调整内存水线差值参数,调整低水线与高水线之间差值,给异步回收预留更多缓冲,回收更多内存;实现调整系统内存回收启动点及回收时间,给内存回收行为更多缓冲,避免一次性大批量内存申请触发直接回收。
Description
技术领域
本发明涉及内存回收领域,具体涉及一种自适应内存回收控制方法、装置、终端及存储介质。
背景技术
随着数据中心及云计算业务的发展,使业务高效、稳定、快速是一直追寻的目标,针对不同的业务及业务高峰低谷情况,内存需求总有差异。目前Linux操作系统下的内存回收路径主要有两种:异步回收,直接回收。内存回收的触发跟内存水线有关系,目前Linux系统中水线分为最小水线(WMARK_MIN)、低水线(WMARK_LOW)、高水线(WMARK_HIGH)。
现有操作系统内存的回机制跟内存分配过程强相关,内存回收的触发是由内存分配出现不足时开始启动回收,这种情况下,内存异步回收的触发条件是当前可用内存已降低至低水线,内存轻微不足,唤醒异步回收线程进行内存回收;直接回收的触发条件是当前可用内存已降低至最小水线,系统内存严重不足,当前进程需要等待其他进程的内存释放才可分配到内存,这种情况会导致进程延迟,损害进程间的隔离性。
当前一些研发人员采取对内存页状态进行监控,同时在物理设备上增加一些低速内存设备,将系统下内存冷页进行迁移,将高速内存资源预留提供给系统正在分配的进程使用,但是这种只是增加物理设备,没有从技术控制角度优化机制。
可见当前内存回收的机制受控于分配过程,这种情况下,系统内存资源的利用率可能通常在比较高的状态,但同时高利用率的内存状态给应用层各种业务带来一些问题,例如在回收效率低于分配效率,系统长时间在高内存使用状态下运行,出现短时大批量内存使用需求时,造成业务状态响应缓慢,进程卡顿等,甚至造成严重的业务中断,因此需要针对这些问题,优化现有机制或者创建新的回收机制,在内存容量固定条件下,保障在合理内存利用率的情况下,系统能够长时间为业务提供大容量内存的储备,为突发的高负载高容量需要预留缓冲,保障业务状态平稳运行。
发明内容
为解决上述问题,本发明提供一种自适应内存回收控制方法、装置、终端及存储介质,根据实时业务对内存资源的需求情况,动态调节控制内存回收,通过对系统下发生直接回收行为的监控,提前启动异步回收,增加异步回收时间;通过动态调整内存水线差值参数,调整低水线与高水线之间差值,给异步回收预留更多缓冲,回收更多内存;通过这两种措施,调整系统内存回收启动点及回收时间,给内存回收行为更多缓冲,避免一次性大批量内存申请触发直接回收。
第一方面,本发明的技术方案提供一种自适应内存回收控制方法,包括以下步骤:
S1,监测预设时间间隔内是否发生直接回收操作;
S2,若发生直接回收操作,则启动异步回收进程;
S3,在异步回收进程中,根据内存消耗速率与回收速率的比值调整内存水线差值,且内存消耗速率与回收速率比值越大,内存水线差值越大;其中内存水线差值指高水线与低水线之间的差值。
进一步地,该方法还包括以下步骤:
S0,预先配置内存消耗速率与回收速率的比值对应的内存水线差值阶梯调节参数;
相应的,步骤S3中根据内存消耗速率与回收速率的比值调整内存水线差值,具体包括:
S31,检测内存消耗速率与回收速率的比值;
S32,在预先配置的阶梯调节参数中,查找当前所检测内存消耗速率与回收速率的比值对应的内存水线差值调节参数;
S33,判断当前内存水线差值是否与所查找的内存水线差值调节参数一致;
S34,若一致,则不动作;若不一致,则根据所查找的内存水线差值调节参数对内存水线差值进行调节。
进一步地,步骤S0中所配置内存消耗速率与回收速率的比值对应的内存水线差值阶梯调节参数,具体包括:
内存消耗速率与回收速率的比值<1,内存水线差值为10;
1≤内存消耗速率与回收速率的比值<1.2,内存水线差值为30;
内存消耗速率与回收速率的比值≥1.2,内存水线差值为80。
进一步地,该方法还包括以下步骤:
S4,监测预设时间间隔内是否未再发生直接回收操作;
S5,若发生直接回收操作,则持续执行步骤S3;
S6,若未再发生直接回收操作,则判断内存消耗速率与回收速率的比值是否小于1,且当前系统可用内存已回收至高水线状态;
S7,若是,则休眠异步回收进程;否则持续执行步骤S3。
进一步地,步骤S0还包括:预先配置预设时间间隔。
进一步地,步骤S1监测预设时间间隔内是否发生直接回收操作,具体包括:
S11,检测预设时间间隔内直接回收计数是否增加;
S12,若增加,则说明发生直接回收操作。
第二方面,本发明的技术方案提供一种自适应内存回收控制装置,包括,
监测模块:监测预设时间间隔内是否发生直接回收操作;
异步回收启停模块:若发生直接回收操作,则启动异步回收进程;
异步回收控制模块:在异步回收进程中,根据内存消耗速率与回收速率的比值调整内存水线差值,且内存消耗速率与回收速率比值越大,内存水线差值越大;其中内存水线差值指高水线与低水线之间的差值。
进一步地,该装置还包括预配置模块:预先配置预设时间间隔,以及预先配置内存消耗速率与回收速率的比值对应的内存水线差值阶梯调节参数。
第三方面,本发明的技术方案提供一种终端,包括:
存储器,用于存储自适应内存回收控制程序;
处理器,用于执行所述自适应内存回收控制程序时实现如上述任一项所述自适应内存回收控制方法的步骤。
第四方面,本发明的技术方案提供一种计算机可读存储介质,所述可读存储介质上存储有自适应内存回收控制程序,所述自适应内存回收控制程序被处理器执行时实现如上述任一项所述自适应内存回收控制方法的步骤。
本发明提供的一种自适应内存回收控制方法、装置、终端及存储介质,在不破坏当前系统回收机制的条件下,通过适当调整,实现如下效果:1.通过监控服务,自适应提前启动(或关闭)kswapd进程进行内存异步回收,降低可用内存消耗速度,一定程度上避免发生直接回收;2.动态调节当前系统下水线差值,增加异步回收进程的回收时间,给异步回收进程更大缓冲时间,提高内存回收量,避免发生直接回收,造成进程服务响应缓慢;3.通过对参数的自定义配置,适应各种业务状态下对内存回收的控制力度,调节异步回收进程回收的积极性,将被动内存回收变得更加主动,在一定程度上提升内存利用效率,提高业务执行效率。
附图说明
为了更清楚的说明本申请实施例或现有技术的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单的介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本发明实施例一提供的一种自适应内存回收控制方法架构原理示意图。
图2是本发明实施例一提供的一种自适应内存回收控制方法流程示意图。
图3是本发明实施例二提供的一种自适应内存回收控制方法流程示意图。
图4是本发明实施例三提供的一种自适应内存回收控制装置结构示意框图。
图5是本发明实施例四提供的一种终端的结构示意图。
具体实施方式
为了使本技术领域的人员更好地理解本申请方案,下面结合附图和具体实施方式对本申请作进一步的详细说明。显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
本发明的核心是提供一种自适应内存回收控制方法,可应用于Linux系统,设计自适应的kswapd唤醒机制,根据当前Linux系统下内核中对直接回收的计数,提前唤醒kswapd回收线程,无需等待当前系统可用内存降至低水线时再启动进程,在不影响进程内存申请的情况下,提前进行主动的内存回收动作;设计自适应的watermark_scale_factor参数调节机制,通过提高watermark_scale_factor参数,控制内存中水线之间的差值,增大低水线与高水线之间的差值,给kswapd预留更大的缓冲空间,让kswapd线程在一次回收中尽可能多的回收内存值,避免短时间中大批量内存申请时速度大于kswapd回收速度,从而避免触发直接回收。
实施例一
本发明实施例一提供一种自适应内存回收控制方法,图1是该方法架构原理示意图,图2是该方法流程原理示意图,该方法具体包括以下步骤。
S1,监测预设时间间隔内是否发生直接回收操作。
S2,若发生直接回收操作,则启动异步回收进程。
需要说明的是,如果未发生直接回收操作,则持续执行步骤S1。
S3,在异步回收进程中,根据内存消耗速率与回收速率的比值调整内存水线差值。
内存消耗速率与回收速率比值越大,内存水线差值越大;其中内存水线差值指高水线与低水线之间的差值。
如图1和2所示,创建监控服务,监控当前系统下内核是否发生直接回收行为,在异步回收进程中监控内存回收效率以及监控内存水线差值。如果在一定时间α内监测到直接回收行为,则唤醒异步回收进程,提前启动异常回收,否则持续监控直接回收行为。在异步回收过程中,监控服务继续负责判断当前系统可能内存的变化,即动态感知内存消耗速率与回收速率的比值。如果内存消耗速率与回收速率的比值较大,则增大内存水线差值,为异常回收进程回收赢得更多时间,如果内存消耗速率与回收速率的比值较小,则降低内存水线差值,降低异步回收进程运行时间,减少系统资源占用。
实施例二
图3是本发明实施例二提供一种自适应内存回收控制方法流程示意图,如图3所示,该方法包括以下步骤。
S0,预先配置内存消耗速率与回收速率的比值对应的内存水线差值阶梯调节参数;预先配置预设时间间隔。
例如,配置预设时间间隔α为30秒。
例如,配置内存消耗速率与回收速率的比值对应的内存水线差值阶梯调节参数,具体为:
内存消耗速率与回收速率的比值<1,内存水线差值为10;
1≤内存消耗速率与回收速率的比值<1.2,内存水线差值为30;
内存消耗速率与回收速率的比值≥1.2,内存水线差值为80。
内存水线差值阶梯调节参数是多级配置调节,可根据业务状态自定义调整,调整参数阶梯数量,以及每一阶梯中的触发条件及调控力。度。
S1,监测预设时间间隔内是否发生直接回收操作。
具体地,通过监测直接回收计数的变化来判断是否有直接回收操作发生。
监控服务监控直接回收计数变化,如果在预设时间间隔30秒内直接回收计数发生变化(直接回收计数在一次系统运行状态下,值只能递增,因此监控变化状态即监控直接回收计数的增加),则说明有直接回收操作发生,此时唤醒异步回收进程进行内存回收。
S2,若发生直接回收操作,则启动异步回收进程;否则持续执行步骤S1。
若发生直接回收操作,表明系统内存没有达到严重不足,提前启动异步回收进行。
S3,在异步回收进程中,根据内存消耗速率与回收速率的比值调整内存水线差值,具体包括:
S31,检测内存消耗速率与回收速率的比值;
S32,在预先配置的阶梯调节参数中,查找当前所检测内存消耗速率与回收速率的比值对应的内存水线差值调节参数;
S33,判断当前内存水线差值是否与所查找的内存水线差值调节参数一致;
S34,若一致,则不动作;若不一致,则根据所查找的内存水线差值调节参数对内存水线差值进行调节。
当前一段时间内系统发送直接回收,需要根据内存消耗速率与回收速率的比值,基于阶梯调节参数,设置当前环境下的内存水线差值,向上或向下调节,此时内存偶发出现严重不足,内存回收速率低于内存消耗速率,需要提升异步回收进程回收时间和积极性,大概率向上调节内存水线差值。
具体地,如果比值<1,则设置当前环境下内存水线差值为10,此时高水线与低水线之间差值较小,异步回收进程执行时间缩短。
如果1<=比值<1.2,则设置当前环境下内存水线差值为30,此时高水线与低水线之间差值中等,异步回收进程执行时间中等。
如果1.2<=比值,则设置当前环境下内存水线差值为80,此时高水线与低水线之间差值较大,异步回收进程执行时间较长。
如果当前比值与当前内存水线差值参数正好对应,则无需调整内存水线差值参数。
S4,监测预设时间间隔内是否未再发生直接回收操作。
S5,若发生直接回收操作,则持续执行步骤S3。
S6,若未再发生直接回收操作,则判断内存消耗速率与回收速率的比值是否小于1,且当前系统可用内存已回收至高水线状态。
S7,若是,则休眠异步回收进程;否则持续执行步骤S3。
如果在一段时间内直接回收计数不再增加,并且内存消耗速率与回收速率的比值小于1,且当前系统可用内存已回收至高水线状态,则休眠异步回收进程,降低资源消耗;监控服务进入守护状态。进一步,如果直接回收计数增加,则重复执行步骤S2-步骤S7。
实施例三
上文中对于一种自适应内存回收控制方法的实施例进行了详细描述,基于上述实施例描述的自适应内存回收控制方法,本发明实施例还提供了一种与该方法对应的自适应内存回收控制装置。
图4是本发明实施例三提供的一种自适应内存回收控制装置结构示意框图,如图4所示,该装置包括预配置模块、监测模块、异步回收启停模块和异步回收控制模块。
预配置模块:预先配置预设时间间隔,以及预先配置内存消耗速率与回收速率的比值对应的内存水线差值阶梯调节参数。
监测模块:监测预设时间间隔内是否发生直接回收操作。
异步回收启停模块:若发生直接回收操作,则启动异步回收进程。
异步回收控制模块:在异步回收进程中,根据内存消耗速率与回收速率的比值调整内存水线差值,且内存消耗速率与回收速率比值越大,内存水线差值越大;其中内存水线差值指高水线与低水线之间的差值。
其中,在异步回收进程启动后,监测模块还用于监测预设时间间隔内是否未再发生直接回收操作,若发生直接回收操作,则持续运行异步回收控制模块;若未再发生直接回收操作,则监测并判断内存消耗速率与回收速率的比值是否小于1,且当前系统可用内存已回收至高水线状态;若是,则通知有回收启停模块休眠异步回收进程;否则持续运行异步回收控制模块。
本实施例的自适应内存回收控制装置用于实现前述的自适应内存回收控制方法,因此该装置中的具体实施方式可见前文中的自适应内存回收控制方法的实施例部分,所以,其具体实施方式可以参照相应的各个部分实施例的描述,在此不再展开介绍。
另外,由于本实施例的自适应内存回收控制装置用于实现前述的自适应内存回收控制方法,因此其作用与上述方法的作用相对应,这里不再赘述。
实施例四
图5为本发明实施例提供的一种终端装置500的结构示意图,包括:处理器510、存储器520及通信单元530。所述处理器510用于实现存储器520中保存的自适应内存回收控制程序时实现以下步骤:
S1,监测预设时间间隔内是否发生直接回收操作;
S2,若发生直接回收操作,则启动异步回收进程;
S3,在异步回收进程中,根据内存消耗速率与回收速率的比值调整内存水线差值,且内存消耗速率与回收速率比值越大,内存水线差值越大;其中内存水线差值指高水线与低水线之间的差值。
本发明在不破坏当前系统回收机制的条件下,通过适当调整,实现如下效果:1.通过监控服务,自适应提前启动(或关闭)kswapd进程进行内存异步回收,降低可用内存消耗速度,一定程度上避免发生直接回收;2.动态调节当前系统下水线差值,增加异步回收进程的回收时间,给异步回收进程更大缓冲时间,提高内存回收量,避免发生直接回收,造成进程服务响应缓慢;3.通过对参数的自定义配置,适应各种业务状态下对内存回收的控制力度,调节异步回收进程回收的积极性,将被动内存回收变得更加主动,在一定程度上提升内存利用效率,提高业务执行效率。
该终端装置500包括处理器510、存储器520及通信单元530。这些组件通过一条或多条总线进行通信,本领域技术人员可以理解,图中示出的服务器的结构并不构成对本发明的限定,它既可以是总线形结构,也可以是星型结构,还可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
其中,该存储器520可以用于存储处理器510的执行指令,存储器520可以由任何类型的易失性或非易失性存储终端或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。当存储器520中的执行指令由处理器510执行时,使得终端500能够执行以下上述方法实施例中的部分或全部步骤。
处理器510为存储终端的控制中心,利用各种接口和线路连接整个电子终端的各个部分,通过运行或执行存储在存储器520内的软件程序和/或模块,以及调用存储在存储器内的数据,以执行电子终端的各种功能和/或处理数据。所述处理器可以由集成电路(Integrated Circuit,简称IC) 组成,例如可以由单颗封装的IC 所组成,也可以由连接多颗相同功能或不同功能的封装IC而组成。举例来说,处理器510可以仅包括中央处理器(Central Processing Unit,简称CPU)。在本发明实施方式中,CPU可以是单运算核心,也可以包括多运算核心。
通信单元530,用于建立通信信道,从而使所述存储终端可以与其它终端进行通信。接收其他终端发送的用户数据或者向其他终端发送用户数据。
实施例五
本发明还提供一种计算机存储介质,这里所说的存储介质可为磁碟、光盘、只读存储记忆体(英文:read-only memory,简称:ROM)或随机存储记忆体(英文:random accessmemory,简称:RAM)等。
计算机存储介质存储有自适应内存回收控制程序,所述自适应内存回收控制程序被处理器执行时实现以下步骤:
S1,监测预设时间间隔内是否发生直接回收操作;
S2,若发生直接回收操作,则启动异步回收进程;
S3,在异步回收进程中,根据内存消耗速率与回收速率的比值调整内存水线差值,且内存消耗速率与回收速率比值越大,内存水线差值越大;其中内存水线差值指高水线与低水线之间的差值。
本发明在不破坏当前系统回收机制的条件下,通过适当调整,实现如下效果:1.通过监控服务,自适应提前启动(或关闭)kswapd进程进行内存异步回收,降低可用内存消耗速度,一定程度上避免发生直接回收;2.动态调节当前系统下水线差值,增加异步回收进程的回收时间,给异步回收进程更大缓冲时间,提高内存回收量,避免发生直接回收,造成进程服务响应缓慢;3.通过对参数的自定义配置,适应各种业务状态下对内存回收的控制力度,调节异步回收进程回收的积极性,将被动内存回收变得更加主动,在一定程度上提升内存利用效率,提高业务执行效率。
本领域的技术人员可以清楚地了解到本发明实施例中的技术可借助软件加必需的通用硬件平台的方式来实现。基于这样的理解,本发明实施例中的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中如U盘、移动硬盘、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质,包括若干指令用以使得一台计算机终端(可以是个人计算机,服务器,或者第二终端、网络终端等)执行本发明各个实施例所述方法的全部或部分步骤。
在本发明所提供的几个实施例中,应该理解到,所揭露的系统、装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。
以上公开的仅为本发明的优选实施方式,但本发明并非局限于此,任何本领域的技术人员能思之的没有创造性的变化,以及在不脱离本发明原理前提下所作的若干改进和润饰,都应落在本发明的保护范围内。
Claims (10)
1.一种自适应内存回收控制方法,其特征在于,包括以下步骤:
S1,监测预设时间间隔内是否发生直接回收操作;
S2,若发生直接回收操作,则启动异步回收进程;
S3,在异步回收进程中,根据内存消耗速率与回收速率的比值调整内存水线差值,且内存消耗速率与回收速率比值越大,内存水线差值越大;其中内存水线差值指高水线与低水线之间的差值。
2.根据权利要求1所述的自适应内存回收控制方法,其特征在于,该方法还包括以下步骤:
S0,预先配置内存消耗速率与回收速率的比值对应的内存水线差值阶梯调节参数;
相应的,步骤S3中根据内存消耗速率与回收速率的比值调整内存水线差值,具体包括:
S31,检测内存消耗速率与回收速率的比值;
S32,在预先配置的阶梯调节参数中,查找当前所检测内存消耗速率与回收速率的比值对应的内存水线差值调节参数;
S33,判断当前内存水线差值是否与所查找的内存水线差值调节参数一致;
S34,若一致,则不动作;若不一致,则根据所查找的内存水线差值调节参数对内存水线差值进行调节。
3.根据权利要求2所述的自适应内存回收控制方法,其特征在于,步骤S0中所配置内存消耗速率与回收速率的比值对应的内存水线差值阶梯调节参数,具体包括:
内存消耗速率与回收速率的比值<1,内存水线差值为10;
1≤内存消耗速率与回收速率的比值<1.2,内存水线差值为30;
内存消耗速率与回收速率的比值≥1.2,内存水线差值为80。
4.根据权利要求3所述的自适应内存回收控制方法,其特征在于,该方法还包括以下步骤:
S4,监测预设时间间隔内是否未再发生直接回收操作;
S5,若发生直接回收操作,则持续执行步骤S3;
S6,若未再发生直接回收操作,则判断内存消耗速率与回收速率的比值是否小于1,且当前系统可用内存已回收至高水线状态;
S7,若是,则休眠异步回收进程;否则持续执行步骤S3。
5.根据权利要求4所述的自适应内存回收控制方法,其特征在于,步骤S0还包括:预先配置预设时间间隔。
6.根据权利要求5所述的自适应内存回收控制方法,其特征在于,步骤S1监测预设时间间隔内是否发生直接回收操作,具体包括:
S11,检测预设时间间隔内直接回收计数是否增加;
S12,若增加,则说明发生直接回收操作。
7.一种自适应内存回收控制装置,其特征在于,包括,
监测模块:监测预设时间间隔内是否发生直接回收操作;
异步回收启停模块:若发生直接回收操作,则启动异步回收进程;
异步回收控制模块:在异步回收进程中,根据内存消耗速率与回收速率的比值调整内存水线差值,且内存消耗速率与回收速率比值越大,内存水线差值越大;其中内存水线差值指高水线与低水线之间的差值。
8.根据权利要求7所示的自适应内存回收控制装置,其特征在于,该装置还包括,
预配置模块:预先配置预设时间间隔,以及预先配置内存消耗速率与回收速率的比值对应的内存水线差值阶梯调节参数。
9.一种终端,其特征在于,包括:
存储器,用于存储自适应内存回收控制程序;
处理器,用于执行所述自适应内存回收控制程序时实现如权利要求1-6任一项所述自适应内存回收控制方法的步骤。
10.一种计算机可读存储介质,其特征在于,所述可读存储介质上存储有自适应内存回收控制程序,所述自适应内存回收控制程序被处理器执行时实现如权利要求1-6任一项所述自适应内存回收控制方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210909660.6A CN115168052A (zh) | 2022-07-29 | 2022-07-29 | 一种自适应内存回收控制方法、装置、终端及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210909660.6A CN115168052A (zh) | 2022-07-29 | 2022-07-29 | 一种自适应内存回收控制方法、装置、终端及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN115168052A true CN115168052A (zh) | 2022-10-11 |
Family
ID=83477730
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210909660.6A Pending CN115168052A (zh) | 2022-07-29 | 2022-07-29 | 一种自适应内存回收控制方法、装置、终端及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115168052A (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN116225976A (zh) * | 2023-05-05 | 2023-06-06 | 麒麟软件有限公司 | 一种Linux操作系统下的水位线自调整方法及系统 |
-
2022
- 2022-07-29 CN CN202210909660.6A patent/CN115168052A/zh active Pending
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN116225976A (zh) * | 2023-05-05 | 2023-06-06 | 麒麟软件有限公司 | 一种Linux操作系统下的水位线自调整方法及系统 |
CN116225976B (zh) * | 2023-05-05 | 2023-08-08 | 麒麟软件有限公司 | 一种Linux操作系统下的水位线自调整方法及系统 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP3091434B1 (en) | Chip starting method, multi-core processor chip and storage medium | |
US20140344620A1 (en) | Shutdown method, startup method, and communication terminal | |
CN112003797B (zh) | 一种虚拟化dpdk网络性能提高方法、系统、终端及存储介质 | |
CN110806925B (zh) | 音频播放方法及设备 | |
CN112650575B (zh) | 资源调度方法、装置和云端服务系统 | |
CN111414069A (zh) | 一种gpu服务器的功耗控制方法、系统及相关组件 | |
EP4404539A1 (en) | Resource scheduling method, apparatus and system, device, medium, and program product | |
CN115361451B (zh) | 一种网络通信并行处理方法及系统 | |
CN110399034A (zh) | 一种SoC系统的功耗优化方法及终端 | |
CN115168052A (zh) | 一种自适应内存回收控制方法、装置、终端及存储介质 | |
CN110557432B (zh) | 一种缓存池均衡优化方法、系统、终端及存储介质 | |
CN113886196B (zh) | 片上功耗管理方法、电子设备及存储介质 | |
CN107179998A (zh) | 一种配置外设内存缓冲区的方法及装置 | |
CN115587049A (zh) | 内存回收方法、装置、电子设备及存储介质 | |
WO2024021485A1 (zh) | 处理器性能调整方法、装置、电子设备及存储介质 | |
CN115757039A (zh) | 一种程序监控方法、装置、电子设备和存储介质 | |
CN114785739A (zh) | 逻辑卷服务质量的控制方法、装置、设备及介质 | |
CN110058866B (zh) | 集群组件安装方法及设备 | |
CN111078405B (zh) | 内存分配方法、装置、存储介质及电子设备 | |
CN114020209A (zh) | 一种客户端业务限速方法、装置、设备及存储介质 | |
CN110955644A (zh) | 一种存储系统的io控制方法、装置、设备及存储介质 | |
CN110737320A (zh) | 耗电量检测方法、装置、电子设备及存储介质 | |
CN114153303B (zh) | 一种功耗控制系统和功耗控制方法、装置、介质 | |
CN115442432B (zh) | 一种控制方法、装置、设备及存储介质 | |
CN111104286B (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 |