Redis源码剖析系列博文开篇&大纲

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 今年我启动了好几个比较有挑战的个人项目,比如写一门编程语言、成为一名视频UP主、写科幻小说…… 这些项目目前进度都很堪忧,一方面这些项目挑战都比较大,另一方面业余时间还要忙着吃吃喝喝、追剧、刷综艺、睡懒觉…… 不过有个项目进度不至于那么不堪,那就是今天的猪脚——《Redis源码剖析》系列博文,今天也是这个系列博文的开篇。为此,我也在github上建立了中文注解版的Redis源码库,详见https://github.com/xindoo/redis,目前已经添加近700行的中文注释,欢迎Star和关注。

今年我启动了好几个比较有挑战的个人项目,比如写一门编程语言、成为一名视频UP主、写科幻小说…… 这些项目目前进度都很堪忧,一方面这些项目挑战都比较大,另一方面业余时间还要忙着吃吃喝喝、追剧、刷综艺、睡懒觉…… 不过有个项目进度不至于那么不堪,那就是今天的猪脚——《Redis源码剖析》系列博文,今天也是这个系列博文的开篇。为此,我也在github上建立了中文注解版的Redis源码库,详见https://github.com/xindoo/redis,目前已经添加近700行的中文注释,欢迎Star和关注。

ca41911e874c22184081891b33940cac_watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3hpbmRvbw==,size_16,color_FFFFFF,t_70#pic_center.png


另外在阅读源码的过程中我也给Redis官方提了PR,目前已经被merge进去了,你可以在git log中看到xindoo我了(当然我只是做了一些微小的工作,不值一提)。


回到今天的主题,开专栏纯属兴趣、没打算收费,没必要在这里贩卖焦虑,Redis里有是有很多值得学习的地方,但并不是非看不可,因为这些东西可能其他地方或者其他项目里也能学到,看不看真的随你意愿。既然是开篇,就主要来介绍下这个项目,并给出我目前的内容规划。


这个专栏是什么不是什么?

首先,这个专栏其实不是一个面向新手的redis教程、也不是什么配置使用教程,如果是初识redis的话,建议参考官方文档,国内也有好多博主写过相关的内容了。另外如果是想找redis的某个具体的配置项,强烈建议参考官方博客。总结起来就一句话,这个项目不是redis的入门读物、更不是redis使用和配置教程。


那这个项目是什么呢?我的目标定位,这个项目是资深程序猿阅读和理解redis源码最优质的中文材料。虽然世面上已有黄建宏老师的redis中文注解版https://github.com/hujianhong/redis-3.0-annotated,但他那个是redis3.0(现在都已经到6.0.x版了),而且多年未更新过了。我这个项目预期做到 源码+中文注释+系列博文 三位一体,全方位帮大家深入理解redis的原理。另外github上我源码库不是redis的copy,而是直接fork出来的,所以会定期和redis当前源码保持一致,时更时新。


这里放上相关链接,欢迎关注

Redis中文注解版仓库:https://github.com/xindoo/redis

Redis源码剖析专栏:https://blog.csdn.net/xindoo/category_10068113.html


已完成内容

Redis源码剖析之内存淘汰策略(Evict)

Redis源码剖析之数据过期(expire)

Redis源码剖析之robj(redisObject)

Redis源码剖析之字典(dict)

Redis源码剖析之跳表(skiplist)

Redis源码剖析之快速列表(quicklist)

Redis源码剖析之压缩列表(ziplist)

Redis源码剖析之SDS(Simple Dynamic String)

Redis源码剖析之RDB

Redis源码剖析之AOF

Redis源码剖析之GEO


内容规划&更新计划

目前暂定的内容规划如下,后期可能会但我自己进度适当增删调整内容,更新频次是每周一篇左右(一月4篇)。


基础

初识Redis

redis的日常使用

搭建redis源码环境(单步调试)

了解redis的启动过程

各种数据结构

SDS(simple dynamic string)

压缩列表ziplist

quicklist

skiplist

dict

robj

GEO

队列

radix树

高级功能

redis的集群模式

发布订阅模式实现

redis6.0客户端缓存

redis stream和消息队列

redis的模块

lua相关

geo

架构

Redis IO模型(单线程如何那么快)

redis6.0的多线程

redis的后台线程

单机和集群模式

集群数据同步

高可用之sentinel

redis后台线程

持久化存储(aof&rdb)

RESP协议

其他

数据数据淘汰之LRU和LFU

redis渐进式hash详解

redis数据过期(惰性删除)

分布式锁 redlock

Redis基于引用计数的垃圾回收

redis使用注意事项

redis常用配置

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
3月前
|
存储 NoSQL Redis
redis 6源码解析之 object
redis 6源码解析之 object
65 6
|
30天前
|
缓存 NoSQL Ubuntu
大数据-39 Redis 高并发分布式缓存 Ubuntu源码编译安装 云服务器 启动并测试 redis-server redis-cli
大数据-39 Redis 高并发分布式缓存 Ubuntu源码编译安装 云服务器 启动并测试 redis-server redis-cli
51 3
|
6月前
|
NoSQL API Redis
Redis源码(1)基本数据结构(上)
Redis源码(1)基本数据结构
76 2
|
6月前
|
NoSQL 安全 Unix
Redis源码、面试指南(4)单机数据库、持久化、通知与订阅(中)
Redis源码、面试指南(4)单机数据库、持久化、通知与订阅
49 0
|
3月前
|
Web App开发 前端开发 关系型数据库
基于SpringBoot+Vue+Redis+Mybatis的商城购物系统 【系统实现+系统源码+答辩PPT】
这篇文章介绍了一个基于SpringBoot+Vue+Redis+Mybatis技术栈开发的商城购物系统,包括系统功能、页面展示、前后端项目结构和核心代码,以及如何获取系统源码和答辩PPT的方法。
|
3月前
|
NoSQL Redis
redis 6源码解析之 ziplist
redis 6源码解析之 ziplist
30 5
|
6月前
|
存储 NoSQL 算法
【Redis技术进阶之路】「底层源码解析」揭秘高效存储模型与数据结构底层实现(字典)(二)
【Redis技术进阶之路】「底层源码解析」揭秘高效存储模型与数据结构底层实现(字典)
114 0
|
6月前
|
NoSQL 安全 算法
Redis源码(1)基本数据结构(中)
Redis源码(1)基本数据结构
69 5
|
6月前
|
存储 NoSQL 算法
Redis源码、面试指南(2)内存编码数据结构(下)
Redis源码、面试指南(2)内存编码数据结构
58 4
|
6月前
|
存储 NoSQL API
Redis源码、面试指南(3)数据对象类型编码(上)
Redis源码、面试指南(3)数据对象类型编码
61 2