BT

你的观点很重要! 快来参与InfoQ调研吧!

Redis开源文档《Redis设计与实现》发布

| 作者 水羽哲 关注 0 他的粉丝 发布于 2013年3月13日. 估计阅读时间: 4 分钟 | ArchSummit社交架构图谱:Facebook、Snapchat、Tumblr等背后的核心技术

Redis是运用比较广泛的NoSQL产品之一,目前的稳定版本是2.6.10,包括GithubInstagram、Blizzard、新浪微博等都在产品中大量使用了Redis。其代码基于BSD协议开源,整个项目代码量只有2万多行(2.2版本),大家可以通过阅读代码在相对短的时间内学习到作者的设计理念和Redis的实现方式,做到知其然知其所以然。

日前黄健宏(huangz)发布了开源文档《Redis设计与实现》,这是一份从阅读源代码入手来学习Redis的笔记合集,对于写这份文档的目的,作者如是说:

本书的目标是以简明易懂的方式讲解 Redis 的内部运行机制, 通过阅读本书, 你可以了解到 Redis 从数据结构到服务器构造在内的几乎所有知识。

《Redis设计与实现》主要从高抽象层次在如下的5个方面对Redis的实现进行阐述:

  1. 内部数据结构
  2. 内存映射数据结构
  3. Redis数据类型
  4. 功能的实现
  5. 部分运作机制

同时作者为了满足大家深入学习的需求,还对Redis 2.6的源代码进行了详细注释

《Redis设计与实现》的作者黄健宏(huangz)是一位90后,喜欢函数式编程,由于对数据库产生了兴趣才开始阅读Redis源代码,他这样看待整个阅读过程:

阅读 Redis 源码对我来说是一次全新的学习体验。当我刚开始看 Redis 源码的时候,我只会一些基本的数据结构和算法,没有任何网络编程、数据库或者系统编程方面的经验,基本是一边看源码,一边补充基础知识,然后才慢慢理解的。

在问到阅读开源项目源代码时应该参照怎样的路线,他分享了自己的一些方法:

  1. 自底向上:从耦合关系最小的模块开始读,然后逐渐过度到关系紧密的模块。就好像写程序的测试一样,先从单元测试开始,然后才到功能测试。我在刚开始读 Redis 源码的时候,使用的就是这种方法:先从单独的数据结构模块开始,然后再过渡到高层的功能模块。

  2. 从功能入手:通过文件名(模块名)和函数名,快速定位到一个功能的具体实现,然后追踪整个实现的运作流程,从而了解该功能的实现方式。我在读阻塞列表、数据库这种流程和功能都比较复杂,和其他文件耦合也比较多的模块时,使用的就是这样的方法。

  3. 自顶向下:从程序的 main() 函数,或者某个特别大的调用者函数为入口,以深度优先或者广度优先的方式阅读它的源码。我在阅读 redis.c/serverCron() 、 redis.c/main() 和 ae.c/aeMain() 这种有明显调用者性质的函数时,使用的就是这样的方法。

然后他强调:

这三种方法并不互相冲突:在某些函数/模块要用某种方法,而某些函数/模块要使用另一种方法,有时候又需要混合使用多种方法。

值得一提的是本书已经以“保留所有权利”的方式开源,大家可以在github上查看内容的创作过程,同时这种开源的协作方式能让更多人参与内容优化中来。

目前在Github上也有很多类似的内容,如:Developing Backbone.js ApplicationsProGit等,也许这种写作方式将会在技术领域引领一个新的内容创作潮流。

亲爱的InfoQ读者,如果你也在阅读开源项目的源代码,并且有一些阅读心得希望和大家分享,欢迎和InfoQ的编辑们联系:editors@cn.infoq.com。

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

Blizzard 也在用 redis by Huang Kyle

请问此文作者怎么知道的 Blizzard 也在用 redis?

Re: Blizzard 也在用 redis by 张 益军

www.csdn.net/article/2011-01-18/290347
"Redis之父Salvatore Sanfilippo访谈":Blizzard (暴雪)使用8节点的Redis来为 WoW (魔兽争霸)提供Avatar服务。

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

2 讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT