自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Linux內核內存管理算法Buddy和Slab

存儲 存儲軟件 算法
在Linux中,伙伴系統(tǒng)(buddy system)是以頁為單位管理和分配內存。但是現(xiàn)實的需求卻以字節(jié)為單位,假如我們需要申請20Bytes,總不能分配一頁吧!那豈不是嚴重浪費內存。

[[251667]]

Buddy分配算法

 

假設這是一段連續(xù)的頁框,陰影部分表示已經(jīng)被使用的頁框,現(xiàn)在需要申請一個連續(xù)的5個頁框。這個時候,在這段內存上不能找到連續(xù)的5個空閑的頁框,就會去另一段內存上去尋找5個連續(xù)的頁框,這樣子,久而久之就形成了頁框的浪費。為了避免出現(xiàn)這種情況,Linux內核中引入了伙伴系統(tǒng)算法(Buddy system)。把所有的空閑頁框分組為11個塊鏈表,每個塊鏈表分別包含大小為1,2,4,8,16,32,64,128,256,512和1024個連續(xù)頁框的頁框塊。最大可以申請1024個連續(xù)頁框,對應4MB大小的連續(xù)內存。每個頁框塊的第一個頁框的物理地址是該塊大小的整數(shù)倍,如圖:

 

假設要申請一個256個頁框的塊,先從256個頁框的鏈表中查找空閑塊,如果沒有,就去512個頁框的鏈表中找,找到了則將頁框塊分為2個256個頁框的塊,一個分配給應用,另外一個移到256個頁框的鏈表中。如果512個頁框的鏈表中仍沒有空閑塊,繼續(xù)向1024個頁框的鏈表查找,如果仍然沒有,則返回錯誤。頁框塊在釋放時,會主動將兩個連續(xù)的頁框塊合并為一個較大的頁框塊。

從上面可以知道Buddy算法一直在對頁框做拆開合并拆開合并的動作。Buddy算法牛逼就牛逼在運用了世界上任何正整數(shù)都可以由2^n的和組成。這也是Buddy算法管理空閑頁表的本質。

空閑內存的信息我們可以通過以下命令獲?。?/p>

 

也可以通過echo m > /proc/sysrq-trigger來觀察buddy狀態(tài),與/proc/buddyinfo的信息是一致的:

 

CMA

細心的讀者或許會發(fā)現(xiàn)當Buddy算法對內存拆拆合合的過程中會造成碎片化的現(xiàn)象,以至于內存后來沒有了大塊的連續(xù)內存,全是小塊內存。當然這對應用程序是不影響的(前面我們講過用頁表可以把不連續(xù)的物理地址在虛擬地址上連續(xù)起來),但是內核態(tài)就沒有辦法獲取大塊連續(xù)的內存(比如DMA, Camera, GPU都需要大塊物理地址連續(xù)的內存)。

在嵌入式設備中一般用CMA來解決上述的問題。CMA的全稱是contiguous memory allocator, 其工作原理是:預留一段的內存給驅動使用,但當驅動不用的時候,CMA區(qū)域可以分配給用戶進程用作匿名內存或者頁緩存。而當驅動需要使用時,就將進程占用的內存通過回收或者遷移的方式將之前占用的預留內存騰出來,供驅動使用。

Slab

在Linux中,伙伴系統(tǒng)(buddy system)是以頁為單位管理和分配內存。但是現(xiàn)實的需求卻以字節(jié)為單位,假如我們需要申請20Bytes,總不能分配一頁吧!那豈不是嚴重浪費內存。那么該如何分配呢?slab分配器就應運而生了,專為小內存分配而生。slab分配器分配內存以Byte為單位。但是slab分配器并沒有脫離伙伴系統(tǒng),而是基于伙伴系統(tǒng)分配的大內存進一步細分成小內存分配。我們先來看一張圖

 

kmem_cache是一個cache_chain的鏈表,描述了一個高速緩存,每個高速緩存包含了一個slabs的列表,這通常是一段連續(xù)的內存塊。存在3種slab:

  • slabs_full(完全分配的slab)
  • slabs_partial(部分分配的slab)
  • slabs_empty(空slab,或者沒有對象被分配)。

slab是slab分配器的最小單位,在實現(xiàn)上一個slab有一個貨多個連續(xù)的物理頁組成(通常只有一頁)。單個slab可以在slab鏈表之間移動,例如如果一個半滿slab被分配了對象后變滿了,就要從slabs_partial中被刪除,同時插入到slabs_full中去。

為了進一步解釋,這里舉個例子來說明,用struct kmem_cache結構描述的一段內存就稱作一個slab緩存池。一個slab緩存池就像是一箱牛奶,一箱牛奶中有很多瓶牛奶,每瓶牛奶就是一個object。分配內存的時候,就相當于從牛奶箱中拿一瓶??傆心猛甑囊惶臁.斚渥涌盏臅r候,你就需要去超市再買一箱回來。超市就相當于partial鏈表,超市存儲著很多箱牛奶。如果超市也賣完了,自然就要從廠家進貨,然后出售給你。廠家就相當于伙伴系統(tǒng)。

可以通過下面命令查看slab緩存的信息:

 

總結

從內存DDR分為不同的ZONE,到CPU訪問的Page通過頁表來映射ZONE,再到通過Buddy算法和Slab算法對這些Page進行管理,我們應該可以從感官的角度理解了下圖:

責任編輯:武曉燕 來源: 人人都是極客
相關推薦

2021-08-10 16:50:37

內核內存管理

2013-10-11 17:24:47

Linux運維內存管理

2022-07-28 08:00:00

Buddy算法內存系統(tǒng)

2021-08-03 09:02:58

LinuxSlab算法

2025-04-07 04:20:00

Linux操作系統(tǒng)內存管理

2025-01-06 08:00:09

2024-12-11 08:18:11

2022-07-19 13:31:18

Buddy算法內存管理框架

2023-10-18 13:31:00

Linux內存

2025-01-02 11:06:22

2009-12-25 15:34:54

slab分配器

2020-12-15 08:54:06

Linux內存碎片化

2018-03-01 16:25:52

Linux內核內存管理

2018-05-18 09:07:43

Linux內核內存

2018-12-06 10:40:50

磁盤緩存內存

2025-03-21 00:00:00

2013-10-11 17:32:18

Linux運維內存管理

2013-10-12 11:15:09

Linux運維內存管理

2024-03-15 08:54:59

Linux內核NUMA

2021-04-15 05:51:25

Linux
點贊
收藏

51CTO技術棧公眾號