redis源碼分析(一):搭建調(diào)試環(huán)境

源碼的獲取方式就不說了,推薦一個(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,就可以開始自嗨了。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容