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

那誰(shuí)的技術(shù)博客

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

memcached內(nèi)存管理算法

簡(jiǎn)單的寫(xiě)寫(xiě),看完了memcached的這部分代碼之后覺(jué)得跟我的ccache還是很像的.

1) 分配
memcached中的內(nèi)存全部由類(lèi)型為slabclass_t的結(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è)全局的slabclass_t的數(shù)組,slabclass_t中的size字段保存每個(gè)slab所能保存的數(shù)據(jù)大小.在這個(gè)slabclass_t數(shù)組中,size字段都是遞增的,遞增的因子由slabs_init函數(shù)中的第二個(gè)參數(shù)factor參數(shù)指定.比如說(shuō),假如factor是2,那么如果第一個(gè)slabclass_t的size是unsigned int size = sizeof(item) + settings.chunk_size;(也是在slabs_init函數(shù)中的語(yǔ)句),那么下一個(gè)slabclass_t的size就是size*factor(這里忽略對(duì)齊的因素).
于是乎,假設(shè)第一個(gè)slab能保存8byte的數(shù)據(jù),factor為2,那么接下來(lái)的slab的size依次為16byte,32byte...
每次需要分配內(nèi)存,都需要根據(jù)所需分配的尺寸查找大于該尺寸的最小尺寸的slab,比如還是前面的那個(gè)slab模型,如果現(xiàn)在需要分配30byte的空間,查找得到大于30byte的最小slab尺寸是32byte,于是就從這個(gè)slab中查找item分配給它.
但是這里有一個(gè)問(wèn)題,就是多余資源的浪費(fèi),前面說(shuō)的30byte只是浪費(fèi)了2byte,但是如果現(xiàn)在要分配的是17byte,那么就浪費(fèi)了15byte,浪費(fèi)了將近50%!因此才有了前面需要指定factor的原因,使用者可以根據(jù)需要指定不同的增長(zhǎng)factor,以降低資源的浪費(fèi).

2) 淘汰
淘汰采用的是LRU算法,所有的最近使用的item保存在static item *tails[LARGEST_ID];(item.c)中,已經(jīng)分配的內(nèi)存會(huì)以鏈表的形式保存在這個(gè)數(shù)組中,如果對(duì)應(yīng)的slab已經(jīng)分配不到足夠的內(nèi)存,就到這個(gè)鏈表中查詢(xún),淘汰的依據(jù)是item結(jié)構(gòu)體中的exptime字段.

簡(jiǎn)單分析到此,需要更詳細(xì)的解釋就去看代碼吧,memcached中與這部分的代碼在slab.h(.c)/item.h(.c)中,兩個(gè)關(guān)鍵的結(jié)構(gòu)體是item和slabclass_t.



posted on 2009-03-09 22:24 那誰(shuí) 閱讀(7085) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): 算法與數(shù)據(jù)結(jié)構(gòu)Linux/Unixmemcached

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久九九精品| 猫咪成人在线观看| 亚洲欧美国产精品va在线观看| 欧美日本在线一区| 日韩午夜精品| 亚洲一区二区黄| 国产欧美日韩综合精品二区| 久久免费视频在线观看| 久久久久久日产精品| 亚洲全部视频| 在线亚洲欧美视频| 韩日在线一区| 亚洲国产欧美另类丝袜| 欧美日韩国产精品| 欧美一区二区三区视频免费| 久久久99爱| 在线视频精品一区| 欧美一区二区三区久久精品| 亚洲日本欧美| 午夜激情亚洲| 亚洲精品久久视频| 亚洲欧美日韩精品久久亚洲区| 一区二区三区亚洲| 一区二区三区视频在线观看| 国内精品久久久久久久97牛牛| 欧美成人资源网| 国产麻豆91精品| 最新高清无码专区| 国产有码一区二区| 日韩午夜在线播放| 伊人精品视频| 亚洲自拍高清| 夜夜嗨av一区二区三区网页| 久久精品色图| 午夜精彩国产免费不卡不顿大片| 久久人人爽人人爽| 欧美在线日韩| 国产精品进线69影院| 亚洲成人在线视频播放 | 久久久久久久999| 亚洲一区二区三区色| 免费在线成人| 久久午夜视频| 国产精品日产欧美久久久久| 亚洲第一福利社区| 黄色一区二区在线观看| 亚洲欧美日韩视频二区| 一本久道久久久| 蜜桃久久精品一区二区| 久久久久久久久久码影片| 国产精品高精视频免费| 亚洲美女毛片| 一本色道久久综合| 欧美福利电影在线观看| 玖玖视频精品| 欲色影视综合吧| 久久精品国产免费观看| 久久精品一区| 国产亚洲综合精品| 亚洲欧美日韩中文播放| 午夜久久资源| 国产精品蜜臀在线观看| 亚洲麻豆视频| 在线中文字幕不卡| 亚洲伊人第一页| 欧美日韩午夜在线| 日韩一级大片| 亚洲综合第一页| 国产精品亚洲一区| 午夜视频在线观看一区二区三区| 午夜亚洲伦理| 国产一区二区三区久久久久久久久| 亚洲女性裸体视频| 久久久噜噜噜久噜久久 | 欧美精品一区二区在线播放| 亚洲激情中文1区| 夜夜嗨av一区二区三区| 欧美午夜精品久久久久久浪潮| 一区二区三区高清不卡| 欧美一区2区三区4区公司二百| 国产美女精品| 久久精品国产999大香线蕉| 裸体丰满少妇做受久久99精品| 在线播放一区| 欧美日本不卡视频| 亚洲午夜激情免费视频| 久久影院午夜论| 亚洲清纯自拍| 国产精品视频精品视频| 久久久999成人| 亚洲乱码国产乱码精品精| 亚洲女同精品视频| 伊人精品成人久久综合软件| 欧美高清视频在线| 午夜精彩国产免费不卡不顿大片| 毛片一区二区三区| 中文亚洲免费| 国模套图日韩精品一区二区| 欧美国产日韩精品| 亚洲欧美偷拍卡通变态| 欧美高清视频在线| 午夜精品福利视频| 亚洲欧洲精品一区二区三区 | 欧美色视频在线| 欧美在线视频播放| 亚洲精品字幕| 看欧美日韩国产| 亚洲欧美韩国| 亚洲人精品午夜| 国产欧美日韩视频| 欧美老女人xx| 久久久久久精| 亚洲一区综合| 亚洲日本精品国产第一区| 久久精品国产精品亚洲综合| 亚洲裸体在线观看| 在线播放视频一区| 国产日产欧美a一级在线| 欧美日韩黄色一区二区| 久久久久久久成人| 午夜精品久久一牛影视| 亚洲卡通欧美制服中文| 欧美高清日韩| 免费成人av资源网| 久久久久国产精品厨房| 亚洲免费在线观看| 一区二区激情视频| 亚洲日本视频| 亚洲国产天堂久久国产91| 国产日韩欧美91| 国产精品成人免费精品自在线观看| 99国产精品国产精品毛片| 欧美激情综合五月色丁香| 久久精品一区蜜桃臀影院 | 久久久久国产精品www| 亚洲欧美日韩区| 亚洲视频免费| 亚洲在线中文字幕| 一本一本久久| 一区二区三区四区五区精品| 亚洲精品一区二区三区蜜桃久| 在线观看av不卡| 在线成人h网| 亚洲国产精品电影| 亚洲激情综合| 亚洲免费观看在线观看| 一个色综合av| 亚洲亚洲精品三区日韩精品在线视频| 亚洲精品你懂的| 在线亚洲+欧美+日本专区| 中国成人黄色视屏| 亚洲一区二区视频在线| 亚洲性视频h| 欧美在线精品免播放器视频| 久久精品30| 老牛影视一区二区三区| 欧美国产先锋| 亚洲精品麻豆| 亚洲一区二区在线播放| 欧美一二三区在线观看| 久久久亚洲高清| 欧美精品一区二区三区一线天视频 | 欧美大片专区| 亚洲欧洲日韩综合二区| 在线亚洲欧美| 久久精品国产久精国产思思| 卡通动漫国产精品| 欧美小视频在线| 国产主播精品| 日韩视频在线观看免费| 亚洲欧美区自拍先锋| 久久久综合免费视频| 亚洲成人在线免费| 一本色道久久88亚洲综合88| 亚洲欧美精品在线| 卡一卡二国产精品| 欧美系列电影免费观看| 韩国精品在线观看| 日韩一级在线观看| 久久精品国产精品亚洲综合| 欧美激情按摩| 亚洲自拍高清| 欧美顶级少妇做爰| 国产精品亚洲片夜色在线| 亚洲国产高清自拍| 香蕉亚洲视频| 亚洲国产精品久久久久婷婷老年| 亚洲特黄一级片| 蜜桃伊人久久| 国产在线不卡| 亚洲在线黄色| 亚洲国产精品久久| 欧美一区二区三区在线观看| 欧美精品二区| 精品成人久久| 久久se精品一区二区| 日韩视频中午一区| 美女主播一区| 狠狠色综合一区二区| 午夜亚洲性色视频|