Redis系列(三):redisServer、redisDb、redisObject、sds四大结构体理解

一.源码下载:

Windows中的Redis源码下载:https://github.com/microsoftarchive/redis/tree/3.2

根据官网说明可知,用VS2013编译,但是必须更新到update5, 否则会出现各种编译错误,确实如此,之前用vs2013的其它版本,出现各种错误,无法修改。

打开VS2013---帮助---关于,即可查看自己的VS版本,例如我重装之后的update5:                                                                   

不是VS2013 update5的可以下载重装。

vs2013 update5下载链接:http://www.121down.com/soft/softview-43319.html

打开RedisServer.sln 一共9个项目:

Redis系列(三):redisServer、redisDb、redisObject、sds四大结构体理解_第1张图片

 

Linux中的Redis源码:http://download.redis.io/releases/redis-6.0.5.tar.gz

二.整体示意图:

Redis系列(三):redisServer、redisDb、redisObject、sds四大结构体理解_第2张图片

 

 

 

 

 

 

三.源码解析

1.redisServer 解析

通过main函数来初始化redisServer()

int main(int argc, char **argv) {
    struct timeval tv;
    int j;
    //.....
    initServer();
}

 

Redis系列(三):redisServer、redisDb、redisObject、sds四大结构体理解_第3张图片

 监听端口

Redis系列(三):redisServer、redisDb、redisObject、sds四大结构体理解_第4张图片

 这里面的server代表的就是redisServer

Redis系列(三):redisServer、redisDb、redisObject、sds四大结构体理解_第5张图片

 初始化db数目

Redis系列(三):redisServer、redisDb、redisObject、sds四大结构体理解_第6张图片

 2.redisDb解析

typedef struct redisDb {
dict *dict; /* The keyspace for this DB */
dict *expires; /* Timeout of keys with a timeout set */
dict *blocking_keys; /* Keys with clients waiting for data (BLPOP)*/
dict *ready_keys; /* Blocked keys that received a PUSH */
dict *watched_keys; /* WATCHED keys for MULTI/EXEC CAS */
int id; /* Database ID */
long long avg_ttl; /* Average TTL, just for stats */
unsigned long expires_cursor; /* Cursor of the active expire cycle. */
list *defrag_later; /* List of key names to attempt to defrag one by one, gradually. */
} redisDb;

 

 

Redis系列(三):redisServer、redisDb、redisObject、sds四大结构体理解_第7张图片

 

Redis系列(三):redisServer、redisDb、redisObject、sds四大结构体理解_第8张图片

3.redisObject解析

typedef struct redisObject {
unsigned type:4;
unsigned encoding:4;
unsigned lru:LRU_BITS; /* LRU time (relative to global lru_clock) or
* LFU data (least significant 8 bits frequency
* and most significant 16 bits access time). */
int refcount;
void *ptr;
} robj;

编码:

 

Redis系列(三):redisServer、redisDb、redisObject、sds四大结构体理解_第9张图片

 类型:

Redis系列(三):redisServer、redisDb、redisObject、sds四大结构体理解_第10张图片

 

 

4.sds解析

在C语言中都是用char数组来存放数据,在Redis中为了性能,封装了char

常用的一种结构体

struct __attribute__ ((__packed__)) sdshdr8 {
    uint8_t len; /* used */
    uint8_t alloc; /* excluding the header and null terminator */
    unsigned char flags; /* 3 lsb of type, 5 unused bits */
    char buf[];
};

Redis系列(三):redisServer、redisDb、redisObject、sds四大结构体理解_第11张图片

 

 

 

注:有兴趣的朋友可以通过cmake把redis编译成vs解决方案项目

 

 

 

 

你可能感兴趣的:(Redis系列(三):redisServer、redisDb、redisObject、sds四大结构体理解)