阿里分布式大神亲码“redis 核心技术笔记”,没有废话,全是干货!
前言
作为这个时代码代码的秃头人员,对 Redis 肯定是不陌生的,如果连 Redis 都没用过,还真不好意思出去面试,指不定被面试官吊打多少次。
毕竟现在互联网公司和一些创业公司都要用到 Redis,像亚马逊、谷歌、阿里、腾讯都要使用,可见精通 Redis 使用真的很有必要。
所以,今天则分享出阿里分布式大神亲自码出的“redis 核心技术笔记”,笔记内容没有讲一句废话,全篇看下来都是精华!
PART1:Redis 深度笔记开篇
1.Redis 可以用来做什么?
由 Redis 面试想到的
Redis 可以做什么?
data:image/s3,"s3://crabby-images/d5ca5/d5ca5c227a7d48e9f1ba36d8937a8b9f76864b75" alt=""
2.Redis 基础数据结构
Redis 安装
Redis 基础的数据结构
容器型数据结构的通用规则
关于 Redis 使用的一些思考
data:image/s3,"s3://crabby-images/fd37d/fd37dd95001c2a862a95b1e980c755295ec99500" alt=""
PART2:Redis 的应用总结
1.分布式锁
分布式锁
超时问题
可重入性
data:image/s3,"s3://crabby-images/dc5ec/dc5ec93f39d318fd36f906febe6f6ef6fb8831f0" alt=""
2.延时队列
异步消息队列?
队列空了怎么办?
队列延迟
空闲连接自动断开
锁冲突处理
延时队列的实现
进一步优化
data:image/s3,"s3://crabby-images/a26ad/a26adc136c10f1423f0e31ec204ab9ed930dd10f" alt=""
3.位图
基本使用
统计和查找
魔术指令 bitfield
data:image/s3,"s3://crabby-images/b7652/b7652ce466bcdc8d91c06dfebf04ef932a48dbe0" alt=""
4.HyperLogLog
使用方法
pfadd 这个 pf 是什么意思?
pfmerge 适合什么场合用?
注意事项
HyperLogLog 实现原理
pf 的内存占用为什么是 12k?
data:image/s3,"s3://crabby-images/5ea9f/5ea9f89adda8573196b8af02c0cbca94cffeb99a" alt=""
5.布隆过滤器
布隆过滤器是什么?
Redis 中的布隆过滤器
布隆过滤器的基本使用
注意事项
布隆过滤器的原理
空间占用估计
实际元素超出时,误判率会怎样变化?
用不上 Redis4.0 怎么办?
布隆过滤器的其他应用
data:image/s3,"s3://crabby-images/24f3c/24f3cfa9f9abaaf6fcd88ae2b32a4b6a4010528a" alt=""
6.简单限流
如何使用 Redis 来实现简单限流策略?
data:image/s3,"s3://crabby-images/cce21/cce2181cb3221b5f226f0913e37d0bfda9059544" alt=""
7.漏斗限流
Redis-Cell
一些思考
data:image/s3,"s3://crabby-images/5b7b2/5b7b2d126d72eb41004368990dc3f9ef24a01036" alt=""
8.GeoHash
用数据库来算附近的人
GeoHash 算法
Redis 的 Geo 指令基本使用
data:image/s3,"s3://crabby-images/ba0aa/ba0aa1a2a6288d4cd85c1b5b3e3bc2138da0c25b" alt=""
9.Scan
scan 基础使用
字典的结构
scan 遍历顺序
字典扩容
对比扩容缩容前后的遍历顺序
渐进式 rehash
更多的 scan 指令
大 Key 扫描
data:image/s3,"s3://crabby-images/d18e3/d18e38c11dc6178812aa04f1204119d048fe8715" alt=""
PART3:Redis 的原理
1.线程 IO 模型
非阻塞 IO
事件轮询(多路复用)
指令队列
响应队列
定时任务
data:image/s3,"s3://crabby-images/b9575/b9575a06d03823e46bd91377d13880d216e88fdf" alt=""
2.通信协议
RESP(Redis Serialization Protocol)
客户端->服务端
服务端->客户端
data:image/s3,"s3://crabby-images/8c8e0/8c8e0519bf9d2a2eb1d75a6745a7a40d0f2e8b35" alt=""
3.持久化
快照原理
fork(多进程)
AOF 原理
AOF 重写
fsync
运维
Redis4.0 混合持久化
data:image/s3,"s3://crabby-images/2babd/2babd6144ec2a76306a52bb20f3039b5ed201c97" alt=""
4.管道
Redis 的消息交互
管道压力测试
深入理解管道本质
data:image/s3,"s3://crabby-images/697c1/697c1c1d61fd24789e093cc5de4d378f4f1ddcff" alt=""
5.事务
Redis 事务的基本使用
原子性
discard(丢弃)
优化
Watch
data:image/s3,"s3://crabby-images/f94a6/f94a695a8250fd0cbce54e79c83d877dae5c844b" alt=""
6.PubSub
消息多播
PubSub
模式订阅
消息结构
PubSub 缺点
data:image/s3,"s3://crabby-images/46f1d/46f1d40bdd3aa7da8936a317031e709c1e06332f" alt=""
7.小对象压缩
32bit vs 64bit
小对象压缩存储(ziplist)
内存回收机制
内存分配算法
data:image/s3,"s3://crabby-images/806cb/806cbe6aa1ebb50d2a1a56b5e5863fd4d80f92cb" alt=""
8.主从同步
CAP 原理
最终一致
主从同步
增量同步
快照同步
增加从节点
无盘复制
Wait 指令
data:image/s3,"s3://crabby-images/f438d/f438d370a08dce86a3772cf1e082892ba461fd4e" alt=""
PART4:Redis 集群
1.Sentinel
消息丢失
Sentinel 基本使用
data:image/s3,"s3://crabby-images/19cf5/19cf56a0eb4114fad9f96776971e39ff4a54f1de" alt=""
2.Codis
Codis 分片原理
不同的 Codis 实例之间槽位关系如何同步?
扩容
自动均衡
Codis 的代价
Codis 的优点
MGET 指令的操作过程
架构变迁
Codis 的尴尬
Codis 的后台管理
data:image/s3,"s3://crabby-images/3a594/3a5945ee40e1c689d457aaafa2c31620437b4d18" alt=""
3.Cluster
槽位定位算法
跳转
迁移
容错
网络抖动
可能下线(PFAIL-Possibly Fail)与确定下线(Fail)
Cluster 基本使用
槽位迁移感知
集群变更感知
data:image/s3,"s3://crabby-images/9b210/9b210b4708db3301c530684a570b325321ebcfc9" alt=""
PART5:Redis 拓展
1.Stream
消息 ID
消息内容
增删改查
独立消费
创建消费组
消费
Stream 消息太多怎么办?
消息如果忘记 ACK 会怎样?
PEL 如何避免消息丢失?
Stream 的高可用
分区 Partition
data:image/s3,"s3://crabby-images/1cf25/1cf256eaca4dd96c7dea9bfe19ebccf58d3971ad" alt=""
2.Info 指令
Redis 每秒执行多少次指令?
Redis 连接了多少客户端?
Redisn 内存占用多大?
复制积压缓存区多大?
data:image/s3,"s3://crabby-images/1095b/1095b40f2825ae4b30821acaf9e05133a8a1f6ac" alt=""
3.再谈分布式锁
Redlock 算法
Redlock 使用场景
data:image/s3,"s3://crabby-images/6cb6d/6cb6decbe377ec05c7dd916ce6b3e0082c4f11a3" alt=""
4.过期策略
过期的 key 集合
定时扫描策略
从库的过期策略
data:image/s3,"s3://crabby-images/89a6c/89a6cd37921c65cc2b62fa0147ed9b9dd32c8d15" alt=""
5.LRU
LRU 算法
近似 LRU 算法
data:image/s3,"s3://crabby-images/4a05a/4a05a24f408bdb9187bd02be97cb2afce934c49e" alt=""
6.懒惰删除
Redis 为什么要懒惰删除(lazy free)?
flush
异步队列
AOF Sync 也很慢
更多异步删除点
data:image/s3,"s3://crabby-images/8638c/8638cd47d237fee64618f1af6e89a24480ee38d8" alt=""
7.优雅地使用 Jedis
重试
data:image/s3,"s3://crabby-images/35cd3/35cd3a706e2db866d3e7fe82bb40b94f941bd558" alt=""
8.保护 Redis
指令安全
端口安全
Lua 脚本安全
SSL 代理
data:image/s3,"s3://crabby-images/7a4c6/7a4c63a59d81ed19b44c861e25456a6219b3695e" alt=""
9.Redis 安全通信
spiped 原理
spiped 使用入门
data:image/s3,"s3://crabby-images/61058/61058392ef4da75c25cb6c3baf06c1b28ad8f94e" alt=""
PART6:源码
1.探索字符串内部结构
embstr vs raw
扩容策略
data:image/s3,"s3://crabby-images/bbdab/bbdab62c059f5ed26ca61ae50b1ea9f3f0d79258" alt=""
2.探索字典内部
dict 内部结构
渐进式 rehash
查找过程
hash 函数
hash 攻击
扩容条件
缩容条件
set 的结构
data:image/s3,"s3://crabby-images/0002c/0002cc482edba4dc14fcd78d8ecce2c990a80b3d" alt=""
3.探索压缩列表内部
增加元素
级联更新
IntSet 小整数集合
data:image/s3,"s3://crabby-images/92dae/92daec7174cae07b01d00f7f8fb9ca6e5bdedd4b" alt=""
4.探索快速列表内部
每个 ziplist 存多少元素?
压缩深度
data:image/s3,"s3://crabby-images/5be58/5be5893d3566b20c88631208e6aa8e22ae32f439" alt=""
5.探索跳跃列表内部结构
基本结构
查找过程
随机层数
插入过程
删除过程
更新过程
如果 score 值都一样呢?
元素排名是怎么算出来的?
data:image/s3,"s3://crabby-images/ff64d/ff64db98db715d36026cc0672f48a630cdcca11b" alt=""
6.探索紧凑列表内部
级联更新
取代 ziplist
data:image/s3,"s3://crabby-images/045aa/045aa0be5f98b82efd5f27022bb175405662e717" alt=""
7.探索基数树内部
应用
结构
增删节点
data:image/s3,"s3://crabby-images/0b45d/0b45d5f324b8ad2ec9d4066841fee610d59c2fee" alt=""
总结
最后,我想说的是,学习并非难事,而贵在坚持,尤其是在我们参与工作之后,要继续坚持学习就更不容易了。但对于程序员来说,学习是立业之根本,如若放弃学习,被市场淘汰是迟早的事情。所以,学习更多新的知识对于自己来说才是一种更大的投资。
以上,到此结束。
提醒,Redis 笔记免费分享,需要的完整 pdf 的朋友,点赞+收藏一下文章,然后加小助理 VX:wjj2632646 领取即可!
版权声明: 本文为 InfoQ 作者【Java架构追梦】的原创文章。
原文链接:【http://xie.infoq.cn/article/5bc51081ddcc48e627000ebf2】。未经作者许可,禁止转载。
评论