看了黄建宏老师的《Redis设计与实现》,对redis的部分实现有了一个简明的认识;
之前面试的时候被问到了这部分的内容,没有关注,好在还有时间,就把Redis的源码看了一遍。
Redis是完全开源的,其源代码可以在直接在GitHub上获取:https://github.com/antirez/redis(目前的版本是4.4.0)
此时,进入解压后的redis目录下的src文件夹,redis的所有源代码都存放在此。
从看到的redis源码阅读方法,我觉得这适用于很多源码的阅读:
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的源码分类大体上如上所述了。
如对本文有疑问, 点击进行留言回复!!
MongoDB中数据的替换方法实现类Replace()函数功能详解
理解Redis持久化,RDB持久化和AOF持久化的不同处理方式
网友评论