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

那誰(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>
            欧美一区二区高清| 欧美在线观看视频一区二区| 欧美性猛交xxxx乱大交蜜桃| 久久一区二区三区国产精品| 久久最新视频| 欧美成年人视频网站欧美| 欧美精品二区三区四区免费看视频| 欧美国产91| 国产精品激情电影| 国产视频久久| 亚洲福利视频一区| 一二三区精品福利视频| 亚洲免费中文| 美女精品视频一区| 亚洲区在线播放| 99在线热播精品免费| 亚洲综合视频一区| 久久久蜜桃精品| 欧美日韩国产在线观看| 国产欧亚日韩视频| 91久久香蕉国产日韩欧美9色| 亚洲网站视频福利| 欧美久久久久久| 亚洲一区二区黄色| 久久亚洲精品欧美| 欧美视频中文字幕| 在线日韩av永久免费观看| 夜夜嗨av一区二区三区四季av| 亚洲影院高清在线| 欧美高清视频www夜色资源网| 99亚洲伊人久久精品影院红桃| 欧美中日韩免费视频| 欧美日韩免费高清一区色橹橹| 国产亚洲精品高潮| 亚洲男人第一网站| 亚洲第一天堂av| 欧美一区二区三区精品| 欧美日本视频在线| 亚洲电影网站| 久久精品亚洲| 亚洲一区亚洲| 欧美日韩免费精品| 亚洲精品精选| 蜜桃av一区| 香蕉久久一区二区不卡无毒影院| 欧美精品一区二区三区在线播放| 黄色亚洲精品| 久久激情五月婷婷| 亚洲在线观看视频网站| 欧美日韩精品免费看| 亚洲人在线视频| 免费国产一区二区| 久久九九久精品国产免费直播| 国产精品美女主播| 亚洲欧美国产精品专区久久| 亚洲国产精品嫩草影院| 久久综合久久综合久久| 伊人成人开心激情综合网| 久久久久91| 欧美主播一区二区三区| 国产欧美va欧美不卡在线| 香蕉国产精品偷在线观看不卡| 在线视频免费在线观看一区二区| 欧美日韩免费在线视频| 亚洲一区二区高清| 亚洲图片激情小说| 国产精品嫩草影院av蜜臀| 亚洲欧美日韩另类精品一区二区三区| 亚洲精品乱码| 国产精品video| 欧美一级专区免费大片| 午夜一区在线| 在线观看日韩欧美| 欧美激情1区| 欧美精品首页| 亚洲视频在线观看三级| 亚洲一区二区在线免费观看视频| 国产精品国产三级国产普通话99| 亚久久调教视频| 久久激情综合| 亚洲精品一区二区三区在线观看| 国产精品另类一区| 欧美一级久久久| 99视频一区二区| 国产喷白浆一区二区三区| 久久久久久91香蕉国产| 女主播福利一区| 制服丝袜激情欧洲亚洲| 香蕉成人伊视频在线观看| 在线看日韩欧美| 日韩午夜在线视频| 国产一区免费视频| 亚洲精华国产欧美| 国产热re99久久6国产精品| 欧美国产精品人人做人人爱| 欧美伦理91| 久久久久天天天天| 欧美成人午夜影院| 欧美一区二区三区四区在线 | 亚洲国产成人不卡| 国产精品xxx在线观看www| 久久福利毛片| 欧美激情久久久久久| 香港久久久电影| 免费在线看成人av| 欧美主播一区二区三区美女 久久精品人| 欧美伊人久久久久久久久影院 | 久久gogo国模裸体人体| 欧美激情久久久| 久久网站热最新地址| 欧美日韩一区二区在线视频 | 国产精品白丝黑袜喷水久久久| 久久婷婷丁香| 国产精品香蕉在线观看| 最新成人av在线| 激情懂色av一区av二区av| 中国女人久久久| 一本一本久久a久久精品牛牛影视| 久久国产精品久久久| 亚洲欧美另类国产| 欧美乱大交xxxxx| 欧美国产免费| 伊人天天综合| 午夜在线精品偷拍| 亚洲欧美在线免费观看| 欧美日韩精品久久久| 91久久精品国产91久久| 亚洲电影自拍| 欧美在线资源| 久久久国产精品一区| 国产欧美在线观看一区| 亚洲综合第一页| 午夜精品久久久久影视| 国产精品成人播放| 亚洲午夜精品久久| 亚洲一级二级在线| 欧美色123| 一本色道久久综合亚洲精品小说| 99精品视频免费观看| 欧美另类综合| 亚洲日本理论电影| 亚洲国产精品一区二区第四页av| 国内精品伊人久久久久av一坑| 亚洲欧美国产精品专区久久| 欧美一级黄色录像| 国产亚洲美州欧州综合国| 欧美一区二区三区免费视频| 久久国产加勒比精品无码| 国产日韩欧美三区| 久久本道综合色狠狠五月| 久久视频在线看| 亚洲国产99| 欧美精品日韩三级| 亚洲一区亚洲| 毛片基地黄久久久久久天堂| 亚洲欧洲午夜| 国产精品高潮粉嫩av| 欧美在线高清视频| 欧美黑人在线播放| 亚洲天堂久久| 国产在线国偷精品产拍免费yy| 久久免费视频这里只有精品| 亚洲娇小video精品| 欧美亚洲一区| 亚洲高清不卡在线| 欧美香蕉大胸在线视频观看| 性色av一区二区三区| 亚洲高清视频一区二区| 亚洲一区二区三区四区视频| 国产视频一区在线观看| 欧美电影资源| 午夜欧美精品| 亚洲精品一区二区三区樱花| 欧美一区亚洲| 999亚洲国产精| 国产精品久久久久久久浪潮网站 | 亚洲一区二区三区777| 国产又爽又黄的激情精品视频 | 亚洲欧美一区二区三区久久| 你懂的网址国产 欧美| 亚洲一区二区成人在线观看| 激情综合在线| 国产精品高潮粉嫩av| 老**午夜毛片一区二区三区| 在线亚洲欧美专区二区| 欧美不卡高清| 久久精品国产精品| 国产精品99久久久久久久久 | 欧美日韩成人激情| 久久精品综合| 亚洲欧美三级伦理| 一区二区三区国产在线观看| 欧美激情第二页| 久久久久这里只有精品| 亚洲女ⅴideoshd黑人| 亚洲三级电影在线观看| 狠狠色噜噜狠狠色综合久| 国产日韩欧美三区| 国产精品一区二区久久久 | 亚洲国产成人av在线|