青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

那誰的技術(shù)博客

感興趣領(lǐng)域:高性能服務(wù)器編程,存儲,算法,Linux內(nèi)核
隨筆 - 210, 文章 - 0, 評論 - 1183, 引用 - 0
數(shù)據(jù)加載中……

memcache內(nèi)存池的設(shè)計(jì)原理

memcache中管理內(nèi)存的數(shù)據(jù)結(jié)構(gòu)如下:

typedef struct {
    unsigned 
int size;      /* sizes of items */
    unsigned 
int perslab;   /* how many items per slab */

    void 
**slots;           /* list of item ptrs */
    unsigned 
int sl_total;  /* size of previous array */
    unsigned 
int sl_curr;   /* first free slot */

    void 
*end_page_ptr;         /* pointer to next free item at end of page, or 0 */
    unsigned 
int end_page_free; /* number of items remaining at end of last alloced page */

    unsigned 
int slabs;     /* how many slabs were allocated for this class */

    void 
**slab_list;       /* array of slab pointers */
    unsigned 
int list_size; /* size of prev array */

    unsigned 
int killing;  /* index+1 of dying slab, or zero if none */
} slabclass_t;

程序中有一個(gè)全局的數(shù)組
static slabclass_t slabclass[POWER_LARGEST + 1]用于保存slab,預(yù)分配內(nèi)存池時(shí)調(diào)用的是void slabs_init(const size_t limit, const double factor) 函數(shù),其中l(wèi)imit是內(nèi)存池的最大容量,factor是分配時(shí)的增長因子.
比方說,加入factor是2,第一個(gè)在slabclass數(shù)組中的slab的每個(gè)item大小是128字節(jié),那么下一個(gè)slab每個(gè)item的大小就是128*2,再下一個(gè)就是128*2*2(注意,為了簡化問題的說明,上面沒有考慮地址對齊的因素).

在預(yù)分配內(nèi)存池時(shí),最多給每個(gè)slab保存item的容量是1M內(nèi)存,這個(gè)數(shù)值由#define POWER_BLOCK 1048576決定.
因此,slab中的幾個(gè)元素在預(yù)分配內(nèi)存時(shí)是這么定的:
size有一個(gè)起始值,這個(gè)值以后的增長由factor決定,增長的過程前面已經(jīng)闡述過了;
perslab保存的是一個(gè)slab存放的item數(shù)量,因此perslab = POWER_BLOCK / slabclass[i].size;
如果預(yù)先分配一段內(nèi)存供使用的話,也就是沒有定義DONT_PREALLOC_SLABS宏,那么就調(diào)用slabs_preallocate進(jìn)行預(yù)分配內(nèi)存.
其中,end_page_ptr指向這個(gè)預(yù)分配好的指針,end_page_free表示的是目前空閑可用item的數(shù)量,在預(yù)分配時(shí),這個(gè)值與perslab相同.
在這個(gè)內(nèi)存池模型中,每個(gè)page實(shí)際上是一個(gè)數(shù)組,數(shù)組中每個(gè)元素的大小就是這個(gè)slab中item的大小.

另外,slots保存的是釋放出來的item指針,sl_total表示總的數(shù)量,sl_curr表示的是目前可用的已經(jīng)釋放出來的item數(shù)量.

每一次要分配內(nèi)存的時(shí)候,首先根據(jù)需要分配的內(nèi)存大小在slabclass數(shù)組中查找索引最小的一個(gè)大于所要求內(nèi)存的slab,如果slots不為空,那么就從這里返回內(nèi)存,否則去查找end_page_ptr,如果也沒有,那么就只能返回NULL了.
每一次釋放內(nèi)存的時(shí)候,同樣的找到應(yīng)該返回內(nèi)存的slab元素,改寫前面提到的slot指針和sl_curr數(shù).

有點(diǎn)倉促,以后再完善~~


posted on 2008-01-21 23:34 那誰 閱讀(7455) 評論(1)  編輯 收藏 引用 所屬分類: C\C++算法與數(shù)據(jù)結(jié)構(gòu)服務(wù)器設(shè)計(jì)

評論

# re: memcache內(nèi)存池的設(shè)計(jì)原理  回復(fù)  更多評論   

我覺得有個(gè)圖的話會描述得更清楚
2008-03-20 14:20 | ycc
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品久久激情| 欧美77777| 国产精品毛片a∨一区二区三区| 午夜视频一区| 午夜精品久久久久久久久| 亚洲精选大片| 国产一区三区三区| 国产午夜精品一区二区三区欧美| 国产精品成人播放| 国产欧美一区二区三区久久人妖 | 一区二区三区 在线观看视| 伊人成人在线| 最新热久久免费视频| 在线视频精品| 嫩草影视亚洲| 亚洲欧美欧美一区二区三区| 久久九九国产| 欧美—级在线免费片| 欧美精品乱人伦久久久久久| 欧美午夜视频一区二区| 亚洲第一色在线| 欧美一级在线播放| 亚洲人体大胆视频| 亚洲网站在线| 欧美深夜影院| 一本色道久久综合精品竹菊| 激情综合电影网| 亚洲视频一二三| 欧美激情一区| 久久亚洲精品欧美| 国内不卡一区二区三区| 亚洲欧美在线一区| 亚洲影院色无极综合| 亚洲高清不卡| 美女精品在线观看| 国产一区二区三区日韩| 亚洲欧美卡通另类91av | 激情久久婷婷| 亚洲调教视频在线观看| 亚洲美女淫视频| 蜜桃av噜噜一区| 国产精品h在线观看| 国产视频观看一区| 一本久道综合久久精品| 久久国产精品久久久久久电车| 亚洲电影第三页| 欧美电影免费| 亚洲精品三级| 亚洲一卡久久| 亚洲国产精品久久久久婷婷884| 久久久久88色偷偷免费| 欧美激情成人在线视频| 国产精品国产三级国产专区53| 亚洲免费网站| 毛片一区二区| 一区二区三区四区国产| 亚洲激情影视| 国产区精品在线观看| 亚洲综合好骚| 久久精彩视频| 亚洲国产精品精华液2区45| 久久精品国产综合精品| 午夜精品视频在线观看| 国内久久精品视频| 日韩一级欧洲| 黄色在线一区| 99国产精品国产精品毛片| 久久永久免费| 老色鬼精品视频在线观看播放 | 嫩模写真一区二区三区三州| 久久伊人亚洲| 久久久精品一区二区三区| 免费在线亚洲欧美| 久久野战av| 欧美国产日韩一区| 久久精品国亚洲| 蜜桃久久精品乱码一区二区| 久久九九久精品国产免费直播| 久久精品中文| 亚洲尤物在线视频观看| 欧美激情麻豆| 亚洲综合大片69999| 久久国产免费看| 亚洲激情在线视频| 欧美色播在线播放| 久久精品中文字幕一区| 日韩午夜精品| 欧美中文字幕在线视频| 欧美视频日韩视频| 欧美一区二区精美| 亚洲国产精品成人一区二区| 亚洲午夜国产成人av电影男同| 国产精品久久久久久久久久尿| 午夜日韩av| 亚洲毛片一区| 欧美a级一区| 亚洲视频在线观看网站| 国产欧美va欧美不卡在线| 久久久国产视频91| 亚洲国产美女精品久久久久∴| 亚洲欧美日韩国产中文| 亚洲激情自拍| 亚洲国产老妈| 亚洲美女中出| 欧美成人久久| 中文一区二区| 国产精品羞羞答答xxdd| 9久re热视频在线精品| 欧美亚洲免费电影| 伊人精品成人久久综合软件| 久久精品主播| 亚洲精品一区在线观看香蕉| 欧美一区二区国产| 一区二区三区视频在线看| 国产综合香蕉五月婷在线| 麻豆国产va免费精品高清在线| 欧美人妖另类| 欧美成人激情视频| 欧美日韩精品一区| 欧美日韩国产在线| 欧美日韩午夜激情| 国产精品男女猛烈高潮激情 | 国产欧美一区二区三区在线老狼 | 欧美一区二区日韩一区二区| 中日韩美女免费视频网址在线观看| 99精品视频免费| 香蕉久久国产| 欧美精品免费在线观看| 欧美午夜三级| 亚洲国产婷婷香蕉久久久久久99| 亚洲欧洲在线一区| 久久精品日产第一区二区| 欧美成年人视频| 欧美一级久久久| 欧美日韩在线亚洲一区蜜芽| 亚洲图色在线| 麻豆av一区二区三区| 欧美久久久久| 在线精品视频免费观看| 亚洲女与黑人做爰| 亚洲激情国产精品| 欧美一区二区三区四区夜夜大片| 欧美精品观看| 亚洲二区在线视频| 久久精品国产视频| 亚洲性夜色噜噜噜7777| 欧美日韩妖精视频| 亚洲开发第一视频在线播放| 久久久精品国产免费观看同学 | 午夜一区在线| 久久亚洲国产精品一区二区| 欧美日韩亚洲高清| 国产欧美精品日韩精品| 黑人巨大精品欧美一区二区小视频 | 国产性天天综合网| 欧美一级片久久久久久久| 日韩网站免费观看| 欧美性猛交99久久久久99按摩 | 美女日韩欧美| 国内外成人免费激情在线视频| av成人免费观看| 亚洲一区视频在线观看视频| 国产精品激情| 久久视频在线视频| 新片速递亚洲合集欧美合集| 精品1区2区3区4区| 亚洲精品综合久久中文字幕| 欧美日韩亚洲一区二区三区| 亚洲激情黄色| 亚洲视频综合在线| 亚洲国产精品va在线看黑人| 亚洲美女精品久久| 国产综合久久| 免费在线国产精品| 亚洲欧洲一区二区天堂久久| 久久久国产精品一区二区中文 | 欧美freesex8一10精品| 欧美wwwwww| 亚洲理论在线观看| 制服丝袜激情欧洲亚洲| 国产无遮挡一区二区三区毛片日本| 欧美综合国产| 欧美精品三级在线观看| 久久久久久久久久久成人| 欧美久久99| 欧美国产在线电影| 国产麻豆一精品一av一免费| 巨胸喷奶水www久久久免费动漫| 欧美日韩第一区日日骚| 久久精品国产2020观看福利| 欧美日韩国产限制| 亚洲国产第一| 在线日韩av永久免费观看| 在线中文字幕日韩| 日韩视频在线观看免费| 亚洲男人av电影| 葵司免费一区二区三区四区五区| 正在播放欧美一区| 欧美精品在线观看播放| 亚洲成人直播|