源码的获取方式就不说了,推荐一个带注释的3.x版本:https://github.com/huangz1990/redis-3.0-annotated
拿到源码以后,可以看到其目录结构,
JjdeMacBook-Pro:redis-3.0-annotated-unstable jjchen$ ls
00-RELEASENOTES COPYING Makefile deps runtest-cluster src
BUGS INSTALL README redis.conf runtest-sentinel tests
CONTRIBUTING MANIFESTO README.rst runtest sentinel.conf utils
这里我们先只关注src:源码目录,deps:部分脚本类头文件依赖。
进入src之后,可以看到源码都在当前目录下了,查看makefile文件,可以看到执行make以后,实际生成了六个可执行文件:
redis-server: redis 服务端
redis-cli: redis 命令行工具
redis-sentinel redis 哨兵(多机下使用,实际就是redis-server)
redis-check-dump,redis-benchmark,redis-check-aof 一些redis工具。
我们现在只关注服务端的程序,查看makefile文件,可得到redis-server 依赖的obj文件。
REDIS_SERVER_OBJ=adlist.o ae.o anet.o dict.o redis.o sds.o zmalloc.o lzf_c.o lzf_d.o pqsort.o zipmap.o sha1.o ziplist.o release.o networking.o util.o object.o db.o replication.o rdb.o t_string.o t_list.o t_set.o t_zset.o t_hash.o config.o aof.o pubsub.o multi.o debug.o sort.o intset.o syncio.o cluster.o crc16.o endianconv.o slowlog.o scripting.o bio.o rio.o rand.o memtest.o crc64.o bitops.o sentinel.o notify.o setproctitle.o blocked.o hyperloglog.o
选择一种ide工具将对应的.c文件添加到项目,我这里选择的是xcode,并添加相应的头文件,库文件。我按照功能将这些.c文件进行了分类,结果是这样的:
localhost:server302 jjchen$ tree
.
├── cluster
│ ├── cluster.c
│ ├── cluster.h
│ ├── replication.c
│ ├── sentinel.c
│ └── syncio.c
├── db
│ ├── bitops.c
│ ├── blocked.c
│ ├── datastruct
│ │ ├── adlist.c
│ │ ├── adlist.h
│ │ ├── dict.c
│ │ ├── dict.h
│ │ ├── hyperloglog.c
│ │ ├── intset.c
│ │ ├── intset.h
│ │ ├── pqsort.c
│ │ ├── pqsort.h
│ │ ├── sds.c
│ │ ├── sds.h
│ │ ├── sort.c
│ │ ├── t_list.c
│ │ ├── t_set.c
│ │ ├── t_string.c
│ │ ├── t_zset.c
│ │ ├── ziplist.c
│ │ ├── ziplist.h
│ │ ├── zipmap.c
│ │ └── zipmap.h
│ ├── db.c
│ ├── multi.c
│ ├── notify.c
│ ├── object.c
│ ├── pubsub.c
│ ├── redis.c
│ ├── redis.h
│ └── storage
│ ├── aof.c
│ ├── bio.c
│ ├── bio.h
│ ├── rdb.c
│ ├── rdb.h
│ ├── slowlog.c
│ └── slowlog.h
├── encoding
│ ├── crc16.c
│ ├── crc64.c
│ ├── crc64.h
│ ├── endianconv.c
│ ├── endianconv.h
│ ├── lzf.h
│ ├── lzfP.h
│ ├── lzf_c.c
│ ├── lzf_d.c
│ ├── sha1.c
│ ├── sha1.h
│ └── t_hash.c
├── network
│ ├── ae.c
│ ├── ae.h
│ ├── ae_kqueue.c
│ ├── anet.c
│ ├── anet.h
│ └── networking.c
├── others
│ ├── asciilogo.h
│ ├── config.c
│ ├── config.h
│ ├── debug.c
│ ├── fmacros.h
│ ├── memtest.c
│ ├── redisassert.h
│ ├── release.c
│ ├── release.h
│ ├── scripting.c
│ ├── setproctitle.c
│ └── version.h
└── utils
├── rand.c
├── rand.h
├── rio.c
├── rio.h
├── util.c
├── util.h
├── zmalloc.c
└── zmalloc.h
下面简述各文件组的作用:
- cluster:多机环境实现。
- db:redis服务的实现,重点。
- encoding: 数据编码有关的实现
- network: 与网络相关的代码,客户端连接实现。
- others: 杂项,低优先级
- utils: 一些辅助类
对比2.x的redis,除了增加功能以外,大大缩减了redis.c文件的大小,把里面的数据结构抽取到新的文件里面,更易于阅读。
启用debug模式调试服务端,在terminal上开个redis-cli,就可以开始自嗨了。