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

那誰的技術(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>
            久久久久久久高潮| 久久久久国产精品一区三寸 | 欧美不卡在线视频| 麻豆精品精品国产自在97香蕉| 精品999久久久| 亚洲激情成人在线| 国产精品美女午夜av| 久久久久88色偷偷免费| 欧美风情在线| 久久成人免费电影| 欧美日韩国产精品一区二区亚洲 | 亚洲欧美另类国产| 亚洲精品一级| 香蕉久久夜色| 在线视频免费在线观看一区二区| 亚洲欧美资源在线| 亚洲午夜伦理| 欧美激情偷拍| 亚洲精品欧美专区| 欧美电影免费观看高清完整版| 久久久91精品国产一区二区三区| 日韩视频一区二区| 免费成人黄色| 久久综合一区二区| 韩国精品在线观看| 欧美在线亚洲一区| 久久精品一区| 国内自拍一区| 久久精品在线观看| 久久综合中文| 91久久中文| 国产精品手机在线| 欧美在线观看网站| 国产一区二区三区精品欧美日韩一区二区三区 | 美国十次成人| 一区二区免费看| 免费成人毛片| 亚洲免费一在线| 国产麻豆精品视频| 欧美成人免费小视频| 亚洲一区二区视频在线| 亚洲国产导航| 久久精品国产久精国产一老狼| 亚洲日本一区二区| 国产乱码精品1区2区3区| 久久最新视频| 销魂美女一区二区三区视频在线| 欧美激情一区二区三级高清视频| 亚洲五月六月| 99国产麻豆精品| 国产自产v一区二区三区c| 91久久久在线| 亚洲精品老司机| 国产午夜精品视频| 亚洲视频二区| 亚洲女同同性videoxma| 欧美黄色网络| 亚洲青色在线| 日韩一区二区电影网| 另类天堂av| 欧美高清在线视频| 在线成人亚洲| 久久在线观看视频| 欧美成人日韩| 亚洲激情成人网| 久久综合狠狠| 亚洲三级免费电影| 一本一本久久a久久精品综合妖精| 欧美激情综合色| 亚洲三级观看| 亚洲性感激情| 国产日韩在线一区二区三区| 先锋影音久久| 欧美岛国激情| 亚洲神马久久| 国产精品中文在线| 久久黄金**| 亚洲国产黄色| 亚洲尤物在线| 国产亚洲综合精品| 美女免费视频一区| 一区二区电影免费在线观看| 香蕉视频成人在线观看| 国产一区二区欧美| 欧美成人午夜激情| 亚洲手机视频| 久久综合一区二区| 正在播放亚洲一区| 国产视频在线观看一区二区| 久久亚洲高清| 一二三区精品福利视频| 久久天天狠狠| 亚洲小少妇裸体bbw| 韩国美女久久| 欧美日韩国产不卡| 久久成人国产精品| 亚洲茄子视频| 久久综合亚洲社区| 亚洲午夜久久久久久尤物| 黄色日韩网站视频| 欧美午夜美女看片| 老司机一区二区| 亚洲一区欧美激情| 亚洲激情第一页| 久久激情婷婷| 亚洲影院在线| 亚洲国产日韩欧美在线图片| 国产精品久久久久久福利一牛影视| 久久激情综合网| 99国产精品私拍| 欧美激情亚洲视频| 欧美一区二粉嫩精品国产一线天| 亚洲欧洲精品一区| 国内精品免费午夜毛片| 国产精品国产精品| 欧美另类videos死尸| 久久精品夜色噜噜亚洲a∨| 艳妇臀荡乳欲伦亚洲一区| 欧美电影打屁股sp| 玖玖玖国产精品| 欧美一区二区三区成人| 中文在线一区| 中文网丁香综合网| 亚洲视频综合| 日韩视频永久免费| 影音先锋另类| 国产在线精品二区| 国产精品女主播| 欧美系列电影免费观看| 欧美日本不卡高清| 欧美激情在线播放| 欧美精品一区二区三区蜜桃| 久久只精品国产| 久久―日本道色综合久久| 欧美一级精品大片| 性欧美1819性猛交| 欧美一区二区三区啪啪| 亚洲欧美中文日韩在线| 亚洲欧美在线x视频| 亚洲欧美日韩国产一区二区| 亚洲一区视频在线| 亚洲综合欧美| 欧美一区免费视频| 欧美一区二区福利在线| 久久国产天堂福利天堂| 久久精品免费播放| 久久综合色播五月| 欧美承认网站| 欧美视频在线观看免费网址| 欧美日韩一二区| 国产精品入口| 黄色成人av网| 亚洲精品乱码久久久久| 日韩视频免费观看| 亚洲综合999| 久久久久久穴| 亚洲国产精品女人久久久| 亚洲国产一区二区a毛片| 夜夜精品视频| 欧美在线播放一区二区| 美女网站久久| 欧美日韩理论| 国产亚洲一区二区精品| 亚洲人成毛片在线播放| 亚洲男人的天堂在线aⅴ视频| 久久成人免费电影| 亚洲丰满少妇videoshd| 亚洲神马久久| 久久天堂av综合合色| 欧美日本一道本在线视频| 国产欧美成人| 亚洲日本乱码在线观看| 午夜精品福利视频| 欧美成黄导航| 亚洲午夜久久久久久久久电影网| 久久成人免费电影| 欧美日韩亚洲一区三区| 国产一区清纯| 亚洲影音一区| 亚洲电影免费观看高清完整版在线观看 | 免费观看在线综合色| 欧美日韩国产高清| 国模精品一区二区三区| 亚洲一区一卡| 欧美a一区二区| 在线中文字幕日韩| 欧美二区视频| 国产在线视频不卡二| 一区二区免费看| 欧美**人妖| 亚洲欧美综合v| 欧美视频成人| 日韩小视频在线观看| 久久久久久久999精品视频| 欧美日韩在线直播| 亚洲精品欧美日韩| 另类尿喷潮videofree| 亚洲私人影院| 欧美三区在线| 日韩一区二区免费高清|