slab简介

在复习epoll的时候注意到了epoll的slab特性,因此对slab进行了下简单的了解。首先slab的出现一是为了避免类似于伙伴系统内存分配方法产生大量内部碎片的问题,二是作为一个高速缓存,可以存储经常分配并释放的对象。

伙伴系统的概念可以参见链接:https://blog.csdn.net/goodluckwhh/article/details/9989695

slab的介绍主要转自链接:http://edsionte.com/techblog/archives/4019

 

1.slab分配器的基本原理

slab分配器中用到了对象这个概念,所谓对象就是内核中的数据结构以及对该数据结构进行创建和撤销的操作。它的基本思想是将内核中经常使用的对象放到高速缓存中,并且由系统保持为初始的可利用状态。比如进程描述符,内核中会频繁对此数据进行申请和释放。当一个新进程创建时,内核会直接从slab分配器的高速缓存中获取一个已经初始化了的对象;当进程结束时,该结构所占的页框并不被释放,而是重新返回slab分配器中。如果没有基于对象的slab分配器,内核将花费更多的时间去分配、初始化以及释放一个对象。

slab分配器有以下三个基本目标:

1.减少伙伴算法在分配小块连续内存时所产生的内部碎片;

2.将频繁使用的对象缓存起来,减少分配、初始化和释放对象的时间开销。

3.通过着色技术调整对象以更好的使用硬件高速缓存;

2.slab分配器的结构

slab分配器为每种对象分配一个高速缓存,这个缓存可以看做是同类型对象的一种储备。每个高速缓存所占的内存区又被划分多个slab,每个slab是由一个或多个连续的页框组成。每个页框中包含若干个对象,既有已经分配的对象,也包含空闲的对象。slab分配器的大致组成图如下:

每个高速缓存通过kmem_cache结构来描述,这个结构中包含了对当前高速缓存各种属性信息的描述。所有的高速缓存通过双链表组织在一起,形成高速缓存链表cache_chain。每个kmem_cache结构中并不包含对具体slab的描述,而是通过kmem_list3结构组织各个slab。slab描述符中的list字段标明了当前slab处于三个slab链表的其中一个。我们将上述的slab分配器进行细化,可以得到下面的结构图:

3.高速缓存的分类

slab高速缓存分为两大类,普通高速缓存和专用高速缓存。普通高速缓存并不针对内核中特定的对象,它首先会为kmem_cache结构本身提供高速缓存,这类缓存保存在cache_cache变量中,该变量即代表的是cache_chain链表中的第一个元素;另一方面,它为内核提供了一种通用高速缓存。专用高速缓存是根据内核所需,通过指定具体的对象而创建。

 

epoll与slab:epoll在被内核初始化时(操作系统启动),同时会开辟出epoll自己的内核高速cache区,用于安置每一个我们想监控的socket,这些socket会以红黑树的形式保存在内核cache里,以支持快速的查找、插入、删除。这个内核高速cache区,就是建立连续的物理内存页,然后在之上建立slab层,简单的说,就是物理上分配好你想要的size的内存对象,每次使用时都是使用空闲的已分配好的对象。

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Slab allocator是一种内存管理算法,用于操作系统中的内核空间。它的主要目的是提高内核内存的分配和释放效率。Slab allocator将内存划分为多个固定大小的块,这些块被称为slabs。当内核需要内存时,它会从一个slab中分配一个或多个块,并在使用后将它们释放回slab中,以便稍后再次使用。 Slab allocator有助于减少内存碎片和内存分配器的开销。它还可以提高内存分配和释放的速度,因为它使用预先分配的内存池来避免频繁的内存分配和释放操作。 在Linux内核中,Slab allocator是可选的,但它已经成为了主流的内存分配器。 ### 回答2: 操作系统中的slab allocator是一种内存分配算法,用于管理操作系统内核中的内存。它的设计目标是提高内存分配的效率和性能。 Slab allocator的思想是将内存划分成大小固定的内存块,称为slab。每个slab由连续的内存页面组成,其中一部分用于存储数据,另一部分用于管理数据块的分配和释放。 slab allocator维护了一个slab链表,每个链表上都是相同大小的slab。当需要分配内存时,slab allocator首先在合适大小的slab链表上查找空闲slab,如果找到,则从slab中分配一个数据块。如果链表上没有可用的slab,则会从内存中分配一个新的slab,并将其加入到链表中。 当需要释放内存时,slab allocator将数据块返回到对应的slab中。如果该slab中的所有数据块都被释放,则该slab会变为空闲状态,并将其从链表中移除。当系统需要更多内存时,slab allocator可以重新使用已经释放的slab。 通过使用slab allocator,操作系统可以减少内存分配和释放的开销。因为每个slab都是固定大小的,所以内存分配和释放的操作非常高效。另外,由于slab可以被重复使用,也减少了对内存的频繁申请和释放,从而提高了系统的整体性能。 总而言之,操作系统的slab allocator是一种高效的内存管理算法,通过减少内存分配和释放的开销,提高了系统的性能和效率。 ### 回答3: 操作系统中的slab allocator是一种用于内存管理的高效分配器。它主要用于解决频繁申请和释放小块内存时产生的内存碎片问题。 Slab allocator的基本思想是将连续的内存空间分为多个大小相等的slab。每个slab包含一定数量的固定大小的内存块。当应用程序需要分配一小块内存时,slab allocator会分配一个完整的slab给应用程序,然后应用程序从slab中分配所需内存块。当应用程序释放内存时,内存块被返回给slab allocator进行重复利用。 对于不同大小的内存块需求,slab allocator会维护一系列自由链表。每个自由链表对应一个固定大小的内存块。当应用程序需要申请内存时,slab allocator会从合适大小的自由链表中找到一个slab。如果没有可用的slab,它会首先去内存池(memory pool)中申请一个新的slab。 通过使用slab allocator,操作系统可以减少内存碎片的产生,并提高内存分配和回收的效率。由于内存分配是以slab为单位进行的,而不是单个页面或字节,所以减少了内存碎片化的问题。此外,重复利用slab中的内存块也减少了频繁分配和释放内存的开销。 总而言之,slab allocator是一种高效的内存管理机制,用于解决内存碎片化问题。它通过预分配和重复利用slab来提高内存分配和回收的效率,从而提高整个系统的性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值