成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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

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

[[251667]]

Buddy分配算法

 

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

 

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

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

空閑內存的信息我們可以通過以下命令獲取:

 

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

 

CMA

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

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

Slab

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

 

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

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

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

為了進一步解釋,這里舉個例子來說明,用struct kmem_cache結構描述的一段內存就稱作一個slab緩存池。一個slab緩存池就像是一箱牛奶,一箱牛奶中有很多瓶牛奶,每瓶牛奶就是一個object。分配內存的時候,就相當于從牛奶箱中拿一瓶。總有拿完的一天。當箱子空的時候,你就需要去超市再買一箱回來。超市就相當于partial鏈表,超市存儲著很多箱牛奶。如果超市也賣完了,自然就要從廠家進貨,然后出售給你。廠家就相當于伙伴系統。

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

 

總結

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

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

2013-10-11 17:24:47

Linux運維內存管理

2021-08-10 16:50:37

內核內存管理

2022-07-28 08:00:00

Buddy算法內存系統

2021-08-03 09:02:58

LinuxSlab算法

2025-04-07 04:20:00

Linux操作系統內存管理

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分配器

2025-06-10 01:22:00

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
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 中文字幕第一页在线 | 亚洲乱码国产乱码精品精的特点 | 天天宗合网 | 亚洲精品粉嫩美女一区 | 日本高清视频在线播放 | 日韩视频中文字幕 | 久久久久久久久久一区二区 | 亚洲精品一区二区三区蜜桃久 | 91视频网| 久久国产成人 | 免费的av| 精品久久视频 | 国产精品成人久久久久a级 久久蜜桃av一区二区天堂 | 欧美成年网站 | 亚洲 欧美 日韩在线 | 五月精品视频 | 成人福利网站 | 99热成人在线| 一区二区三区视频在线 | 色悠悠久| 亚洲韩国精品 | 久久精品国产久精国产 | 精品婷婷| 久久久成人免费一区二区 | 激情黄色在线观看 | 91精品久久久久久久久中文字幕 | 古装三级在线播放 | 天天草夜夜骑 | 欧美乱操 | 伊人久久国产 | 久久这里有精品 | 五月天婷婷狠狠 | 97精品国产97久久久久久免费 | a级毛片毛片免费观看久潮喷 | 电影午夜精品一区二区三区 | av在线播放网址 | 精品欧美乱码久久久久久 | 欧洲高清转码区一二区 | 在线视频 欧美日韩 | 欧美一区二区激情三区 | 蜜桃av鲁一鲁一鲁一鲁 |