内核态内存计数在线关闭方法技术

技术编号:39503591 阅读:7 留言:0更新日期:2023-11-24 11:34
本发明专利技术公开了一种内核态内存计数在线关闭方法

【技术实现步骤摘要】
内核态内存计数在线关闭方法、装置、电子设备和介质


[0001]本专利技术涉及计算机应用
,尤其涉及一种内核态内存计数在线关闭方法

装置

电子设备和介质


技术介绍

[0002]随着云计算行业的发展,虚拟化技术逐渐发展,越来越多的云厂商采用
Linux
操作系统作为其云平台操作系统
。Linux
操作系统采用开源的
Linux
内核,提供了除基础操作系统外的虚拟化功能,其中,
cgroup
技术为容器平台提供了资源隔离功能,包括但不限于对计算

内存

存储等资源进行隔离,而内核态技术可以对容器资源使用的用户态以及内核态内存进行区分统计,在该功能出现之前,容器的可使用内存仅包括用户态内存,该内核态功能打开后,容器的可使用内存将包括内核态以及用户态内存,也即会将内核态内存统计至可使用内存中,从而使容器更精确的限制内核态与用户态内存使用的总和

但该功能存在一些问题,即内核态的缓存也会被统计至内核态内存中,而
Linux
内核采用优先进行缓存的原则,因此在当缓存占用较多时,
Linux
内核可供用户态使用的内存将减少,如需分配内存,则会主动释放回收内核态缓存,导致占用较多额外时间开销,应用业务性能严重下降

为解决上述问题,需要将内核态内存计数关闭,以回收业务运行性能,但是现有技术内该功能无法在线关闭,只能通过修改内核配置参数并重启主机实现,导致业务系统运行存在中断,极大影响了业务的连续性,导致业务系统可靠性较低


技术实现思路

[0003]本专利技术提供了一种内核态内存计数在线关闭方法

装置

电子设备和介质,以解决现有技术中内核态计数功能无法在线关闭的问题,可减少业务系统由于功能关闭导致的服务中断,可提高业务连续性,增强业务系统可靠性

[0004]根据本专利技术的一方面,提供了一种内核态内存计数在线关闭方法,其中,该方法包括:
[0005]根据热补丁加载预设计数替代函数;
[0006]响应于内核态计数关闭指令,初始化内核态内存的计数关闭状态;
[0007]根据所述预设计数替代函数截获所述内核态内存对应的原始计数实现函数

[0008]根据本专利技术的另一方面,提供了一种内核态内存计数在线关闭装置,其中,该装置包括:
[0009]功能加载模块,用于根据热补丁加载预设计数替代函数;
[0010]计数关闭模块,用于响应于内核态计数关闭指令,初始化内核态内存的计数关闭状态;
[0011]函数处理模块,用于根据所述预设计数替代函数截获所述内核态内存对应的原始计数实现函数

[0012]根据本专利技术的另一方面,提供了一种电子设备,所述电子设备包括:
[0013]至少一个处理器;以及
[0014]与所述至少一个处理器通信连接的存储器;其中,
[0015]所述存储器存储有可被所述至少一个处理器执行的计算机程序,所述计算机程序被所述至少一个处理器执行,以使所述至少一个处理器能够执行本专利技术任一实施例所述的内核态内存计数在线关闭方法

[0016]根据本专利技术的另一方面,提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机指令,所述计算机指令用于使处理器执行时实现本专利技术任一实施例所述的内核态内存计数在线关闭方法

[0017]本专利技术实施例的技术方案,通过热补丁将预设计数替代函数进行加载,在获取到内核态计数关闭指令时对内核态内存的计数关闭状态进行初始化,依据预设计数替代函数对统计内核态内存的原始计数实现函数进行截获,从而实现内核态内存的在线关闭,可减少业务系统由于内核态内存统计关闭导致的服务中断,可提高业务连续性,增强业务系统可靠性

[0018]应当理解,本部分所描述的内容并非旨在标识本专利技术的实施例的关键或重要特征,也不用于限制本专利技术的范围

本专利技术的其它特征将通过以下的说明书而变得容易理解

附图说明
[0019]为了更清楚地说明本专利技术实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本专利技术的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图

[0020]图1是根据本专利技术实施例一提供的一种内核态内存计数在线关闭方法的流程图;
[0021]图2是根据本专利技术实施例二提供的另一种内核态内存计数在线关闭方法的流程图;
[0022]图3是根据本专利技术实施例三提供的一种内核态内存计数在线关闭装置的结构示意图;
[0023]图4是根据本专利技术实施例四提供的一种内核态内存计数在线关闭的示例图;
[0024]图5是实现本专利技术实施例的内核态内存计数在线关闭方法的电子设备的结构示意图

具体实施方式
[0025]为了使本
的人员更好地理解本专利技术方案,下面将结合本专利技术实施例中的附图,对本专利技术实施例中的技术方案进行清楚

完整地描述,显然,所描述的实施例仅仅是本专利技术一部分的实施例,而不是全部的实施例

基于本专利技术中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本专利技术保护的范围

[0026]需要说明的是,本专利技术的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序

应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本专利技术的实施例能够以除了在这里图示或
描述的那些以外的顺序实施

此外,术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程

方法

系统

产品或设备不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程

方法

产品或设备固有的其它步骤或单元

[0027]实施例一
[0028]图1是根据本专利技术实施例一提供的一种内核态内存计数在线关闭方法的流程图,本实施例可适用于在线关闭内核内存计数的情况,该方法可以由内核态内存计数在线关闭装置来执行,该内核态内存计数在线关闭装置可以采用硬件和
/
或软件的形式实现,该内核态内存计数在线关闭装置可配置于服务器中

如图1所示,该方法包括:
[0029]步骤
110、
根据热补丁加载预设计数替代函数

[本文档来自技高网
...

【技术保护点】

【技术特征摘要】
1.
一种内核态内存计数在线关闭方法,其特征在于,所述方法包括:根据热补丁加载预设计数替代函数;响应于内核态计数关闭指令,初始化内核态内存的计数关闭状态;根据所述预设计数替代函数截获所述内核态内存对应的原始计数实现函数
。2.
根据权利要求1所述方法,其特征在于,所述根据热补丁加载预设计数替代函数,包括:读取所述预设计数替代函数,其中,所述预设计数替代函数至少包括内存增长替代函数以及内存减少替代函数;将所述预设计数函数以所述热补丁加载至系统内核
。3.
根据权利要求1所述方法,其特征在于,所述响应于内核态计数关闭指令,初始化内核态内存的计数关闭状态,包括:确定监测到所述内核态计数关闭指令,在系统内核置位所述计数关闭状态的关闭标识
。4.
根据权利要求1所述方法,其特征在于,所述根据所述预设计数替代函数截获所述内核态内存对应的原始计数实现函数,包括:监测所述内核态内存的处理请求;确定所述处理请求对应的所述原始计数实现函数;选择所述原始计数实现函数对应的所述预设计数替代函数截获所述原始计数实现函数
。5.
根据权利要求4所述方法,其特征在于,所述处理请求至少包括以下至少之一:内核态内存申请请求

内核态内存释放请求
。6.
根据权利要求4所述方法,其特征在于,所述选择所述原始计数实现函数对应的所述预设计数替代函数截获所述原始计数实现函数,包括:在所述原始计数实现函数包括
memcg_kmem_charge
函数,
memcg_kmem_charge_memcg

【专利技术属性】
技术研发人员:孙锋
申请(专利权)人:北京青云科技股份有限公司
类型:发明
国别省市:

网友询问留言 已有0条评论
  • 还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。

1