首页 > 其他 > 详细

Memcached源码分析之item结构

时间:2014-03-25 00:41:52      阅读:537      评论:0      收藏:0      [点我收藏+]

item是Memcached中抽象实际数据的结构,我们分析下item的一些特性,便于后续Memcached的其他特性分析。

typedef struct _stritem {
    struct _stritem *next;//item在slab中存储时,是以双链表的形式存储的,next即后向指针
    struct _stritem *prev;//prev为前向指针
    struct _stritem *h_next;//Hash桶中元素的链接指针
    rel_time_t      time; //最近访问时间
    rel_time_t      exptime;//过期时间
    int             nbytes;//数据大小
    unsigned short  refcount;//引用次数
    uint8_t         nsuffix;    //不清楚什么意思?
    uint8_t         it_flags;   //不清楚什么意思?
    uint8_t         slabs_clsid;//标记item属于哪个slabclass下
    uint8_t         nkey;       //key的长度
    union {
        uint64_t cas;
        char end;
    } data[];//真实的数据信息
} item;

其结构图如下所示:

bubuko.com,布布扣

即Item由两部分组成,item的属性信息和item的数据部分,属性信息解释如上,数据部分包括cas,key和真实的value信息,item在内存中的存储形式如下:

bubuko.com,布布扣

这个图画出了部分结构,还有Hash表的结构没有画出。

bubuko.com,布布扣


这里大概介绍了item的一些信息,后面我们会分析item插入Hash表等信息。

注:本篇博客的图片摘自:http://kenby.iteye.com/blog/1423989

                                               http://www.nosqlnotes.net/archives/222

                                               

Memcached源码分析之item结构,布布扣,bubuko.com

Memcached源码分析之item结构

原文:http://blog.csdn.net/lcli2009/article/details/21985793

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!