chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線(xiàn)課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

探究slab在內(nèi)核內(nèi)存管理和用戶(hù)態(tài)Memcached的雙重存在

B4Pb_gh_6fde77c ? 來(lái)源:Linux閱碼場(chǎng) ? 作者: 宋寶華 ? 2021-08-13 14:55 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

很多基礎(chǔ)的概念,將跨越軟件的層次而存在。比如slab,對(duì)于內(nèi)核人員,我們都知道slab是buddy之上的一層。

因?yàn)閎uddy作為Linux內(nèi)核最底層的內(nèi)存管理器,它分配1頁(yè),2頁(yè),4頁(yè),2^n頁(yè),但是作為內(nèi)核的堆用戶(hù)本身,經(jīng)常只是調(diào)用kmalloc()申請(qǐng)一個(gè)小內(nèi)存,或者調(diào)用kmem_cache_alloc()申請(qǐng)一個(gè)數(shù)據(jù)結(jié)構(gòu),2^n頁(yè)給它,會(huì)形成大量碎片浪費(fèi)。所以slab找buddy要了2^n頁(yè)后,內(nèi)部切割為同樣size的object,再給kmalloc和kmem_cache_alloc()拿走。

697d87de-fbba-11eb-9bcf-12bb97331649.png

它的邏輯如下:

6991d324-fbba-11eb-9bcf-12bb97331649.png

這樣一種軟件本質(zhì)意義上的需求,不會(huì)因?yàn)橹皇莾?nèi)核就需要。比如同樣的slab算法,也被著名的用戶(hù)態(tài)軟件Memcached需要著。

Memcached是一種分布式內(nèi)存對(duì)象緩存系統(tǒng),用于動(dòng)態(tài)Web等應(yīng)用以減輕數(shù)據(jù)庫(kù)的負(fù)載。它在內(nèi)存中緩存數(shù)據(jù)和對(duì)象,使用key-value對(duì)形式存儲(chǔ)。它的網(wǎng)站首頁(yè)(https://memcached.org/)顯示了它的基本用法邏輯:

Memcached的原理也類(lèi)似內(nèi)核態(tài)page cache的原理:

69a6c658-fbba-11eb-9bcf-12bb97331649.jpg

比如你查詢(xún)一個(gè)數(shù)據(jù)庫(kù),可以先看看Memcached里面有沒(méi)有命中,命中就直接從Memcached的內(nèi)存里面拿到值了,沒(méi)有的時(shí)候才需要去查數(shù)據(jù)庫(kù)。查到后,可以把結(jié)果放入Memcached,這樣下次再訪問(wèn)同樣數(shù)據(jù),不再需要進(jìn)行數(shù)據(jù)庫(kù)的查詢(xún)動(dòng)作。

Memcached也同樣采用slab分配算法來(lái)組織數(shù)據(jù)的存放,里面可以組織不同大小的chunks:

正如Linux內(nèi)核的每一種不同slab里面的object的大小不一樣。

我們安裝1個(gè)Memcached:

$ sudo apt-get install memcached

然后啟動(dòng)起來(lái),你馬上看到memcached打印說(shuō)自己創(chuàng)建了各種不同chunk size的slab:

69d4799a-fbba-11eb-9bcf-12bb97331649.png

當(dāng)然,還有更多的相似性,比如Memcached里面的對(duì)象,也是LRU算法替換。所以LRU這種,也是一種本質(zhì)上的事情。

編輯:jq

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Web
    Web
    +關(guān)注

    關(guān)注

    2

    文章

    1287

    瀏覽量

    71450
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11511

    瀏覽量

    213839
  • 數(shù)據(jù)庫(kù)
    +關(guān)注

    關(guān)注

    7

    文章

    3927

    瀏覽量

    66254
  • 管理器
    +關(guān)注

    關(guān)注

    0

    文章

    254

    瀏覽量

    19064

原文標(biāo)題:宋寶華:slab在內(nèi)核內(nèi)存管理和用戶(hù)態(tài)Memcached的雙重存在

文章出處:【微信號(hào):gh_6fde77c41971,微信公眾號(hào):FPGA干貨】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    雙重驅(qū)動(dòng)的新型直線(xiàn)電機(jī)研究

    摘罷:大行程、高精度,同時(shí)易于小型化的移動(dòng)機(jī)構(gòu)是先進(jìn)制造業(yè)等領(lǐng)域要解決的關(guān)鍵問(wèn)題之一,綜述了現(xiàn)有宏/微雙重驅(qū)動(dòng)機(jī)構(gòu)和直線(xiàn)超聲電機(jī)的研究進(jìn)展和存在問(wèn)題,提出了一種宏微雙重驅(qū)動(dòng)新型直線(xiàn)壓電電機(jī),使其既能
    發(fā)表于 06-24 14:17

    harmony OS NEXT-通過(guò)用戶(hù)首選項(xiàng)實(shí)現(xiàn)數(shù)據(jù)持久化

    存儲(chǔ)的地方,可以采用用戶(hù)首選項(xiàng)來(lái)進(jìn)行存儲(chǔ)。Preferences會(huì)將該數(shù)據(jù)緩存在內(nèi)存中,當(dāng)用戶(hù)讀取的時(shí)候,能夠快速?gòu)?b class='flag-5'>內(nèi)存中獲取數(shù)據(jù),當(dāng)需要持久化時(shí)可以使用flush接口將
    的頭像 發(fā)表于 04-29 16:38 ?546次閱讀

    Linux系統(tǒng)中通過(guò)預(yù)留物理內(nèi)存實(shí)現(xiàn)ARM與FPGA高效通信的方法

    管理子系統(tǒng)管理。因此,需要預(yù)留一部分物理內(nèi)存,使其不被內(nèi)核管理。接下來(lái)將為大家詳細(xì)介紹在 Linux 系統(tǒng)中通過(guò)預(yù)留物理
    的頭像 發(fā)表于 04-16 13:42 ?685次閱讀
    Linux系統(tǒng)中通過(guò)預(yù)留物理<b class='flag-5'>內(nèi)存</b>實(shí)現(xiàn)ARM與FPGA高效通信的方法

    嵌入式學(xué)習(xí)-飛凌嵌入式ElfBoard ELF 1板卡-內(nèi)核空間與用戶(hù)空間的數(shù)據(jù)拷貝之?dāng)?shù)據(jù)拷貝介紹

    本帖最后由 jf_13411809 于 2025-3-20 14:10 編輯 在Linux系統(tǒng)中,內(nèi)核空間和用戶(hù)空間是兩個(gè)獨(dú)立的地址空間,它們有不同的訪問(wèn)權(quán)限和內(nèi)存保護(hù)機(jī)制。在內(nèi)核
    發(fā)表于 03-20 11:50

    飛凌嵌入式ElfBoard ELF 1板卡-內(nèi)核空間與用戶(hù)空間的數(shù)據(jù)拷貝之?dāng)?shù)據(jù)拷貝介紹

    在Linux系統(tǒng)中,內(nèi)核空間和用戶(hù)空間是兩個(gè)獨(dú)立的地址空間,它們有不同的訪問(wèn)權(quán)限和內(nèi)存保護(hù)機(jī)制。在內(nèi)核空間和用戶(hù)空間之間進(jìn)行數(shù)據(jù)傳輸時(shí),需要
    發(fā)表于 03-19 08:55

    嵌入式學(xué)習(xí)-飛凌嵌入式ElfBoard ELF 1板卡-Linux內(nèi)核移植之內(nèi)核啟動(dòng)流程

    關(guān)于內(nèi)核啟動(dòng)流程涉及內(nèi)容較多而且復(fù)雜,過(guò)度的分析意義不大,因此,這里不做詳細(xì)講解,只做一個(gè)大概的介紹。初學(xué)者只做了解,有一定基礎(chǔ)的可以深入理解。內(nèi)核鏡像被uboot加載到內(nèi)存空間之后,獲得控制權(quán)
    發(fā)表于 01-07 09:20

    飛凌嵌入式ElfBoard ELF 1板卡-Linux內(nèi)核移植之內(nèi)核啟動(dòng)流程

    關(guān)于內(nèi)核啟動(dòng)流程涉及內(nèi)容較多而且復(fù)雜,過(guò)度的分析意義不大,因此,這里不做詳細(xì)講解,只做一個(gè)大概的介紹。初學(xué)者只做了解,有一定基礎(chǔ)的可以深入理解。 內(nèi)核鏡像被uboot加載到內(nèi)存空間之后,獲得控制權(quán)
    發(fā)表于 01-06 09:51

    Redis緩存與Memcached的比較

    Redis和Memcached都是廣泛使用的內(nèi)存數(shù)據(jù)存儲(chǔ)系統(tǒng),它們主要用于提高應(yīng)用程序的性能,通過(guò)減少對(duì)數(shù)據(jù)庫(kù)的直接訪問(wèn)來(lái)加速數(shù)據(jù)檢索。以下是對(duì)Redis和Memcached的比較,涵蓋了它們的一些
    的頭像 發(fā)表于 12-18 09:33 ?597次閱讀

    虛擬內(nèi)存溢出該怎么處理 虛擬內(nèi)存在服務(wù)器中的應(yīng)用

    在現(xiàn)代計(jì)算機(jī)系統(tǒng)中,虛擬內(nèi)存是一種重要的資源管理技術(shù),它允許系統(tǒng)使用硬盤(pán)空間來(lái)擴(kuò)展物理內(nèi)存的容量。然而,當(dāng)系統(tǒng)運(yùn)行的程序和進(jìn)程超出了物理內(nèi)存和虛擬內(nèi)
    的頭像 發(fā)表于 12-04 09:49 ?826次閱讀

    Linux下如何管理虛擬內(nèi)存 使用虛擬內(nèi)存時(shí)的常見(jiàn)問(wèn)題

    在Linux系統(tǒng)中,虛擬內(nèi)存管理是操作系統(tǒng)內(nèi)核的一個(gè)重要功能,負(fù)責(zé)管理物理內(nèi)存和磁盤(pán)上的交換空間。以下是對(duì)Linux下如何
    的頭像 發(fā)表于 12-04 09:19 ?1341次閱讀

    嵌入式工程師都在找的【Linux內(nèi)核調(diào)試技術(shù)】建議收藏!

    printk()調(diào)用,可以直接將關(guān)心的信息打印到屏幕上,從而觀察程序的執(zhí)行路徑和變量的變化情況。 printk()類(lèi)似于用戶(hù)空間的printf(),但它在內(nèi)核空間使用,并受到內(nèi)核日志系統(tǒng)的
    發(fā)表于 11-28 15:37

    Linux內(nèi)存管理中HVO的實(shí)現(xiàn)原理

    代碼閱讀工具:vim+ctags+cscope本文主要介紹內(nèi)存管理中的HVO(HugeTLB Vmemmap Optimization)特性,通過(guò)HVO可以節(jié)省管理HugeTLB 頁(yè)面元數(shù)據(jù)
    的頭像 發(fā)表于 10-22 16:51 ?705次閱讀
    Linux<b class='flag-5'>內(nèi)存</b><b class='flag-5'>管理</b>中HVO的實(shí)現(xiàn)原理

    Windows管理內(nèi)存的三種主要方式

    Windows操作系統(tǒng)提供了多種方式來(lái)管理內(nèi)存,以確保系統(tǒng)資源的有效利用和性能的優(yōu)化。以下是關(guān)于Windows管理內(nèi)存的三種主要方式的詳細(xì)闡述,包括堆
    的頭像 發(fā)表于 10-12 17:09 ?2390次閱讀

    線(xiàn)上活動(dòng) | 新思科技 2024 內(nèi)存用戶(hù)大會(huì),專(zhuān)注于內(nèi)存設(shè)計(jì)與開(kāi)發(fā)!

    思科技?2024 內(nèi)存用戶(hù)大會(huì)(線(xiàn)上活動(dòng)) 新思科技內(nèi)存用戶(hù)大會(huì)”是一場(chǎng)專(zhuān)注于內(nèi)存設(shè)計(jì)與開(kāi)發(fā)的線(xiàn)上盛會(huì),匯聚
    發(fā)表于 09-26 14:36 ?203次閱讀
    線(xiàn)上活動(dòng) | 新思科技 2024 <b class='flag-5'>內(nèi)存</b><b class='flag-5'>用戶(hù)</b>大會(huì),專(zhuān)注于<b class='flag-5'>內(nèi)存</b>設(shè)計(jì)與開(kāi)發(fā)!

    內(nèi)存管理的硬件結(jié)構(gòu)

    常見(jiàn)的內(nèi)存分配函數(shù)有malloc,mmap等,但大家有沒(méi)有想過(guò),這些函數(shù)在內(nèi)核中是怎么實(shí)現(xiàn)的?換句話(huà)說(shuō),Linux內(nèi)核內(nèi)存管理是怎么實(shí)現(xiàn)的
    的頭像 發(fā)表于 09-04 14:28 ?661次閱讀
    <b class='flag-5'>內(nèi)存</b><b class='flag-5'>管理</b>的硬件結(jié)構(gòu)