腾讯云大神亲码“redis 深度笔记”,不讲一句废话,全是精华
data:image/s3,"s3://crabby-images/cc2ac/cc2ac62b16cbc9622a2a8190b3db24bcabdb6d70" alt="腾讯云大神亲码“redis深度笔记”,不讲一句废话,全是精华"
前言
作为这个时代码代码的秃头人员,对 Redis 肯定是不陌生的,如果连 Redis 都没用过,还真不好意思出去面试,指不定被面试官吊打多少次。
毕竟现在互联网公司和一些创业公司都要用到 Redis,像亚马逊、谷歌、阿里、腾讯都要使用,可见精通 Redis 使用真的很有必要。
所以,今天则分享出腾讯云大神亲自码出的“redis 深度笔记”,笔记内容没有讲一句废话,全篇看下来都是精华!
需要 Redis 深度笔记 PDF 版的,可以帮忙三连支持一下,点击下方传送门即可入手~
点击免费领取:腾讯云大神亲码“redis深度笔记”及脑图电子版教程
data:image/s3,"s3://crabby-images/85501/855014f636aab713b56c948404a778a347a38e45" alt=""
PART1:Redis 深度笔记开篇
1.Redis 可以用来做什么?
由 Redis 面试想到的
Redis 可以做什么?
data:image/s3,"s3://crabby-images/4b54e/4b54e5504020159759ab0e8089fad2d72e3b265b" alt=""
2.Redis 基础数据结构
Redis 安装
Redis 基础的数据结构
容器型数据结构的通用规则
关于 Redis 使用的一些思考
data:image/s3,"s3://crabby-images/dab9f/dab9f0817d03ad39ec2d2127226a4d6353f4cc46" alt=""
PART2:Redis 的应用总结
1.分布式锁
分布式锁
超时问题
可重入性
data:image/s3,"s3://crabby-images/fdacb/fdacb12d116da065a5ea8e11c912fc497e383ee1" alt=""
2.延时队列
异步消息队列?
队列空了怎么办?
队列延迟
空闲连接自动断开
锁冲突处理
延时队列的实现
进一步优化
data:image/s3,"s3://crabby-images/e3a3e/e3a3eeb51a906fad8ee6703f1a4ab117de7543a6" alt=""
3.位图
基本使用
统计和查找
魔术指令 bitfield
data:image/s3,"s3://crabby-images/6e2c8/6e2c806fb2cdf8b470c77d524cd0c5eebc929fd4" alt=""
4.HyperLogLog
使用方法
pfadd 这个 pf 是什么意思?
pfmerge 适合什么场合用?
注意事项
HyperLogLog 实现原理
pf 的内存占用为什么是 12k?
data:image/s3,"s3://crabby-images/dcdf0/dcdf04cf8242f8dca4f381a510a09528da1e5b9f" alt=""
5.布隆过滤器
布隆过滤器是什么?
Redis 中的布隆过滤器
布隆过滤器的基本使用
注意事项
布隆过滤器的原理
空间占用估计
实际元素超出时,误判率会怎样变化?
用不上 Redis4.0 怎么办?
布隆过滤器的其他应用
data:image/s3,"s3://crabby-images/88e77/88e77a9a00b8f4127b7816c5097f479a97b36905" alt=""
6.简单限流
如何使用 Redis 来实现简单限流策略?
data:image/s3,"s3://crabby-images/113df/113df7984879a81138953f0715d0ee0c899f985e" alt=""
7.漏斗限流
Redis-Cell
一些思考
data:image/s3,"s3://crabby-images/9e8b1/9e8b160e3eba233647a5639f96c6decfe7ead759" alt=""
8.GeoHash
用数据库来算附近的人
GeoHash 算法
Redis 的 Geo 指令基本使用
data:image/s3,"s3://crabby-images/222f7/222f7894a753d9ad4beda664accee5b4ecc4caa2" alt=""
9.Scan
scan 基础使用
字典的结构
scan 遍历顺序
字典扩容
对比扩容缩容前后的遍历顺序
渐进式 rehash
更多的 scan 指令
大 Key 扫描
data:image/s3,"s3://crabby-images/9ade6/9ade67222a09d557df49894e34c84736305fee34" alt=""
PART3:Redis 的原理
1.线程 IO 模型
非阻塞 IO
事件轮询(多路复用)
指令队列
响应队列
定时任务
data:image/s3,"s3://crabby-images/0d096/0d096b89baa09e97af783686351582d544bbd086" alt=""
2.通信协议
RESP(Redis Serialization Protocol)
客户端->服务端
服务端->客户端
data:image/s3,"s3://crabby-images/21e4d/21e4de04f5f42d9272e211b4247c9d44c0cf897f" alt=""
3.持久化
快照原理
fork(多进程)
AOF 原理
AOF 重写
fsync
运维
Redis4.0 混合持久化
data:image/s3,"s3://crabby-images/29320/29320490ac0f9598f83c4cfc060d70048ddf4df9" alt=""
4.管道
Redis 的消息交互
管道压力测试
深入理解管道本质
data:image/s3,"s3://crabby-images/c0eac/c0eac967053abc6ac28eb664ec6501974e3a8525" alt=""
5.事务
Redis 事务的基本使用
原子性
discard(丢弃)
优化
Watch
data:image/s3,"s3://crabby-images/6422b/6422b177b48bca959508889bd2dcab4d94b84bda" alt=""
6.PubSub
消息多播
PubSub
模式订阅
消息结构
PubSub 缺点
data:image/s3,"s3://crabby-images/85081/850810c7db2f74b2886ce135087987e14a37aacd" alt=""
7.小对象压缩
32bit vs 64bit
小对象压缩存储(ziplist)
内存回收机制
内存分配算法
data:image/s3,"s3://crabby-images/28fad/28fadbf412f88defa1880e08e102b8f7e0596ddd" alt=""
8.主从同步
CAP 原理
最终一致
主从同步
增量同步
快照同步
增加从节点
无盘复制
Wait 指令
data:image/s3,"s3://crabby-images/702ad/702ad8ef75c64c17d7072f81753db297d7e04df8" alt=""
PART4:Redis 集群
1.Sentinel
消息丢失
Sentinel 基本使用
data:image/s3,"s3://crabby-images/20c0a/20c0ae5b1366984079cf0b7c98eaf80227e21b2c" alt=""
2.Codis
Codis 分片原理
不同的 Codis 实例之间槽位关系如何同步?
扩容
自动均衡
Codis 的代价
Codis 的优点
MGET 指令的操作过程
架构变迁
Codis 的尴尬
Codis 的后台管理
data:image/s3,"s3://crabby-images/c42b1/c42b1dc965b349f93f4ccc22e60c42d712961327" alt=""
3.Cluster
槽位定位算法
跳转
迁移
容错
网络抖动
可能下线(PFAIL-Possibly Fail)与确定下线(Fail)
Cluster 基本使用
槽位迁移感知
集群变更感知
data:image/s3,"s3://crabby-images/4dbf4/4dbf4eaa51c2832b92786d057e1b31400cf8ac6d" alt=""
PART5:Redis 拓展
1.Stream
消息 ID
消息内容
增删改查
独立消费
创建消费组
消费
Stream 消息太多怎么办?
消息如果忘记 ACK 会怎样?
PEL 如何避免消息丢失?
Stream 的高可用
分区 Partition
data:image/s3,"s3://crabby-images/4677b/4677bf37b24d42299507caa67293888727bbdfb9" alt=""
Redis 每秒执行多少次指令?
Redis 连接了多少客户端?
Redisn 内存占用多大?
复制积压缓存区多大?
data:image/s3,"s3://crabby-images/591c7/591c78c62c6c62a956d31d34821b29077eb41b07" alt=""
3.再谈分布式锁
Redlock 算法
Redlock 使用场景
data:image/s3,"s3://crabby-images/7a99b/7a99bbadff1069f038d8ca99bfe56301d33e093d" alt=""
4.过期策略
过期的 key 集合
定时扫描策略
从库的过期策略
data:image/s3,"s3://crabby-images/2a863/2a8635181f3b558983542d2111defe15db3f3523" alt=""
5.LRU
LRU 算法
近似 LRU 算法
data:image/s3,"s3://crabby-images/de659/de659346a93efa5dd5c43e4480365523e524636f" alt=""
6.懒惰删除
Redis 为什么要懒惰删除(lazy free)?
flush
异步队列
AOF Sync 也很慢
更多异步删除点
data:image/s3,"s3://crabby-images/48af1/48af1694beaf305eebc64b1042e8b95b0dc8fa75" alt=""
7.优雅地使用 Jedis
重试
data:image/s3,"s3://crabby-images/932e5/932e5b84dff4ada3b92d02b6c76a69fa2cefcab5" alt=""
8.保护 Redis
指令安全
端口安全
Lua 脚本安全
SSL 代理
data:image/s3,"s3://crabby-images/c782e/c782e4a4cf380330de26efdb5918b5273732b1ad" alt=""
9.Redis 安全通信
spiped 原理
spiped 使用入门
data:image/s3,"s3://crabby-images/e0739/e0739d8bc47edcc974435f3369b829ea60a918e7" alt=""
PART6:源码
1.探索字符串内部结构
embstr vs raw
扩容策略
data:image/s3,"s3://crabby-images/0d054/0d054b89e6ad5b95a4dfa5bb5322efddc278423c" alt=""
2.探索字典内部
dict 内部结构
渐进式 rehash
查找过程
hash 函数
hash 攻击
扩容条件
缩容条件
set 的结构
data:image/s3,"s3://crabby-images/9f0c2/9f0c2dae32adc60cc2843f4c9d464107d9bbc2d6" alt=""
3.探索压缩列表内部
增加元素
级联更新
IntSet 小整数集合
data:image/s3,"s3://crabby-images/5e1c8/5e1c82de347aaaa07ae9f5efbc6ad489217527d6" alt=""
4.探索快速列表内部
每个 ziplist 存多少元素?
压缩深度
data:image/s3,"s3://crabby-images/ac2c7/ac2c7d597639442635e845c1a46ee31b44433eb2" alt=""
5.探索跳跃列表内部结构
基本结构
查找过程
随机层数
插入过程
删除过程
更新过程
如果 score 值都一样呢?
元素排名是怎么算出来的?
data:image/s3,"s3://crabby-images/07d6b/07d6be91a3eabdf62adbbc151dec7cdaaf7d3ae5" alt=""
6.探索紧凑列表内部
级联更新
取代 ziplist
data:image/s3,"s3://crabby-images/3bb39/3bb394a115e2b13dea0604660bcf7f32ac444c26" alt=""
7.探索基数树内部
应用
结构
增删节点
data:image/s3,"s3://crabby-images/dfe22/dfe2210c1c76628924a9037f329942659e5658ac" alt=""
总结
最后,我想说的是,学习并非难事,而贵在坚持,尤其是在我们参与工作之后,要继续坚持学习就更不容易了。但对于程序员来说,学习是立业之根本,如若放弃学习,被市场淘汰是迟早的事情。所以,学习更多新的知识对于自己来说才是一种更大的投资。
以上,到此结束。
评论