创意电子

标题: 怎样使用空闲时间高效深入地阅读Redis的源码? [打印本页]

作者: Java干货分享    时间: 2021-9-8 17:16
标题: 怎样使用空闲时间高效深入地阅读Redis的源码?
前言

学习了黄建宏老师的《Redis设计与实现》之后,对redis的部门实现有了一个简明的认识。在口试过程中,redis确实成为了口试官考核我的一个亮点,恰好以后的工作又与redis有着千丝万缕的联系,于是就想趁着毕业前的这段时间把redis的源代码研究一下,为以后的工作打个精良的底子。


Redis简介
redis全称REmote DIctionary Server,是一个由Salvatore Sanfilippo写的高性能key-value存储系统,其完全开源免费,服从BSD协议。Redis与其他key-value缓存产品(如memcache)有以下几个特点。
Redis的性能极高且拥有丰富的数据类型,同时,Redis所有操作都是原子性的,也支持对几个操作合并后原子性的执行。另外,Redis有丰富的扩展特性,它支持publish/subscribe, 关照,key 过期等等特性。
Redis更为优秀的地方在于,它的代码风格极其精简,整个源码只有23000行,很有利于阅读和赏析!还在等什么呢?Start!
如何获取Redis源码?
redis是完全开源的,其源代码可以在直接在官网上获取(目前最新版本是3.2.5)。执行以下指令:
cd ... // 这里打开你存放redis的文件夹wget http://download.redis.io/releases/redis-3.2.5.tar.gztar zxvf redis-3.2.5.tar.gz此时,进入解压后的redis目次下的src文件夹,redis的所有源代码都存放在此。
[root@VM_123_20_centos redis-3.2.5]# cd src/[root@VM_123_20_centos src]# lsMakefile      crc64.h        mkreleasehdr.sh    redis-cli.o     sort.oMakefile.dep  crc64.o        multi.c            redis-sentinel  sparkline.cadlist.c      db.c           multi.o            redis-server    sparkline.hadlist.h      db.o           networking.c       redis-trib.rb   sparkline.oadlist.o      debug.c        networking.o       redisassert.h   syncio.cae.c          debug.o        notify.c           release.c       syncio.oae.h          debugmacro.h   notify.o           release.h       t_hash.cae.o          dict.c         object.c           release.o       t_hash.oae_epoll.c    dict.h         object.o           replication.c   t_list.cae_evport.c   dict.o         pqsort.c           replication.o   t_list.oae_kqueue.c   endianconv.c   pqsort.h           rio.c           t_set.cae_select.c   endianconv.h   pqsort.o           rio.h           t_set.oanet.c        endianconv.o   pubsub.c           rio.o           t_string.canet.h        fmacros.h      pubsub.o           scripting.c     t_string.oanet.o        geo.c          quicklist.c        scripting.o     t_zset.caof.c         geo.h          quicklist.h        sds.c           t_zset.oaof.o         geo.o          quicklist.o        sds.h           testhelp.hasciilogo.h   help.h         rand.c             sds.o           util.cbio.c         hyperloglog.c  rand.h             sdsalloc.h      util.hbio.h         hyperloglog.o  rand.o             sentinel.c      util.obio.o         intset.c       rdb.c              sentinel.o      valgrind.supbitops.c      intset.h       rdb.h              server.c        version.hbitops.o      intset.o       rdb.o              server.h        ziplist.cblocked.c     latency.c      redis-benchmark    server.o        ziplist.hblocked.o     latency.h      redis-benchmark.c  setproctitle.c  ziplist.ocluster.c     latency.o      redis-benchmark.o  setproctitle.o  zipmap.ccluster.h     lzf.h          redis-check-aof    sha1.c          zipmap.hcluster.o     lzfP.h         redis-check-aof.c  sha1.h          zipmap.oconfig.c      lzf_c.c        redis-check-aof.o  sha1.o          zmalloc.cconfig.h      lzf_c.o        redis-check-rdb    slowlog.c       zmalloc.hconfig.o      lzf_d.c        redis-check-rdb.c  slowlog.h       zmalloc.ocrc16.c       lzf_d.o        redis-check-rdb.o  slowlog.ocrc16.o       memtest.c      redis-cli          solarisfixes.hcrc64.c       memtest.o      redis-cli.c        sort.c源代码结构剖析
看了上面src目次下的文件,简直让人眼花缭乱。这里不得不品评以下redis的作者啊,都没有整理一下源代码,统统都放在一个文件夹下。
正所谓不打无准备的仗,拿到源码之后,我们首先要对这些文件进行一个分类,来规划一下我们的阅读顺序。这里介绍一下在网上看到的源码阅读方法(摘自redis源码剖析)。
按照上图对Redis源码的模块分别,初步确定一下源码的学习路线如下:
第一阶段
第二阶段 熟悉Redis的内存编码结构
第三阶段 熟悉Redis数据类型的实现
第四阶段 熟悉Redis数据库的实现
以及一些独立功能模块的实现
第五阶段 熟悉客户端和服务器端的代码实现
第六阶段 这一阶段主要是熟悉Redis多机部门的代码实现
其他代码文件介绍

关于测试方面的文件有:
一些工具类的文件如下:
整个Redis的源码分类大体上如上所述了,接下来就按照既定的几个阶段一一去分析Redis这款如此优秀的源代码吧!
又给自己制定了一个艰巨的计划,希望自己能像之前一样坚持下去,一点一点去分析,相信最后会收获很多!
推荐阅读:

口试十余家大厂,因Redis答得好都让我明天入职!
这份阿里逆天的Redis手册,于内卷中首次亮相了




欢迎光临 创意电子 (https://wxcydz.cc/) Powered by Discuz! X3.4