源碼的獲取方式就不說了,推薦一個(gè)帶注釋的3.x版本:https://github.com/huangz1990/redis-3.0-annotated
拿到源碼以后,可以看到其目錄結(jié)構(gòu),
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
這里我們先只關(guān)注src:源碼目錄,deps:部分腳本類頭文件依賴。
進(jìn)入src之后,可以看到源碼都在當(dāng)前目錄下了,查看makefile文件,可以看到執(zhí)行make以后,實(shí)際生成了六個(gè)可執(zhí)行文件:
redis-server: redis 服務(wù)端
redis-cli: redis 命令行工具
redis-sentinel redis 哨兵(多機(jī)下使用,實(shí)際就是redis-server)
redis-check-dump,redis-benchmark,redis-check-aof 一些redis工具。
我們現(xiàn)在只關(guān)注服務(wù)端的程序,查看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工具將對(duì)應(yīng)的.c文件添加到項(xiàng)目,我這里選擇的是xcode,并添加相應(yīng)的頭文件,庫(kù)文件。我按照功能將這些.c文件進(jìn)行了分類,結(jié)果是這樣的:
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
下面簡(jiǎn)述各文件組的作用:
- cluster:多機(jī)環(huán)境實(shí)現(xiàn)。
- db:redis服務(wù)的實(shí)現(xiàn),重點(diǎn)。
- encoding: 數(shù)據(jù)編碼有關(guān)的實(shí)現(xiàn)
- network: 與網(wǎng)絡(luò)相關(guān)的代碼,客戶端連接實(shí)現(xiàn)。
- others: 雜項(xiàng),低優(yōu)先級(jí)
- utils: 一些輔助類
對(duì)比2.x的redis,除了增加功能以外,大大縮減了redis.c文件的大小,把里面的數(shù)據(jù)結(jié)構(gòu)抽取到新的文件里面,更易于閱讀。
啟用debug模式調(diào)試服務(wù)端,在terminal上開個(gè)redis-cli,就可以開始自嗨了。