当前位置: 移动技术网 > IT编程>数据库>MongoDB > redis源代码结构解析

redis源代码结构解析

2018年02月28日  | 移动技术网IT编程  | 我要评论

看了黄建宏老师的《Redis设计与实现》,对redis的部分实现有了一个简明的认识;

之前面试的时候被问到了这部分的内容,没有关注,好在还有时间,就把Redis的源码看了一遍。

Redis源码的获取

Redis是完全开源的,其源代码可以在直接在GitHub上获取:https://github.com/antirez/redis(目前的版本是4.4.0)

此时,进入解压后的redis目录下的src文件夹,redis的所有源代码都存放在此。

源代码结构解析

从看到的redis源码阅读方法,我觉得这适用于很多源码的阅读:

  1. 自底向上:从耦合关系最小的模块开始读,然后逐渐过度到关系紧密的模块。就好像写程序的测试一样,先从单元测试开始,然后才到功能测试。
  2. 从功能入手:通过文件名(模块名)和函数名,快速定位到一个功能的具体实现,然后追踪整个实现的运作流程,从而了解该功能的实现方式。
  3. 自顶向下:从程序的 main() 函数,或者某个特别大的调用者函数为入口,以深度优先或者广度优先的方式阅读它的源码。

Redis的数据结构部分

内存分配 zmalloc.c和zmalloc.h
动态字符串 sds.h和sds.c
双端链表 adlist.c和adlist.h
字典 dict.h和dict.c
跳跃表 server.h文件里面关于zskiplist结构和zskiplistNode结构,以及t_zset.c中所有zsl开头的函数

 

 

 

 

 

Redis的内存编码

整数集合 intset.h和intset.c
压缩列表 ziplist.h和ziplist.c
压缩表 zipmap.h和zipmap.c

 

 

 

Redis数据类型

对象 object.c
字符串对象 t_string.c
列表对象 t_list.c
散列对象 t_hash.c
集合对象 t_set.c
有序集合对象 t_zset.c中除 zsl 开头的函数之外的所有函数

 

 

 

 

 

Redis数据库的实现

数据库实现 db.c
RDB持久化 rdb.c
AOF持久化 aof.c
通知功能 notify.c

 

 

 

 

客户端和服务器端的代码实现

服务器端 redis.c
客户端 redis-cli.c
事件处理 ae.c/ae_epoll.c/ae_evport.c/ae_kqueue.c/ae_select.c
网络链接 anet.c和networking.c

 

 

 

 

Redis多机部分的代码实现

复制功能 replication.c
Redis Sentinel sentinel.c
集群 cluster.c

 

 

 

独立功能模块的实现

发布和订阅 pubsub.c文件
事务 multi.c
lua脚本 scripting.c
慢查询 slowlog.c
监视 monitor.c

 

 

 

 

 

整个Redis的源码分类大体上如上所述了。

 

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网