腾讯云大神呕心沥血整理:redis 深度笔记”,看完全面掌握 redis 核心技术
前言作为这个时代码代码的秃头人员,对 Redis 肯定是不陌生的,如果连 Redis 都没用过,还真不好意思出去面试,指不定被面试官吊打多少次。毕竟现在互联网公司和一些创业公司都要用到 Redis,像亚马逊、谷歌、阿里、腾讯都要使用,可见精通 Redis 使用真的很有必要。所以,今天则分享出腾讯云大神亲自码出的“redis 深度笔记”,笔记内容没有讲一句废话,全篇看下来都是精华!
data:image/s3,"s3://crabby-images/16e93/16e937c57793216023ee035592cf1ef09a175431" alt=""
Ps:由于篇幅限制,笔记无法全部为大家展示出来,就以截图主要内容的形式让大家参考啦,需要完整的朋友可以点击>>传送门<<获取
开篇
1.Redis 可以用来做什么?
由 Redis 面试想到的
Redis 可以做什么?
data:image/s3,"s3://crabby-images/1086e/1086e723255026779d87e1789f62d884a1883354" alt=""
2.Redis 基础数据结构
Redis 安装
Redis 基础的数据结构
容器型数据结构的通用规则
关于 Redis 使用的一些思考
data:image/s3,"s3://crabby-images/6a396/6a3962eed1fd0964213172300783d66423c8ae24" alt=""
PART2:Redis 的应用总结 1.分布式锁
分布式锁
超时问题
可重入性
data:image/s3,"s3://crabby-images/500fc/500fc8a9b8c063c56c53a787d4b5a197cf1bca89" alt=""
2.延时队列
异步消息队列?
队列空了怎么办?
队列延迟
空闲连接自动断开
锁冲突处理
延时队列的实现
进一步优化
data:image/s3,"s3://crabby-images/5b490/5b490fd9fcf372c9b47dbb18993853c1e5f07372" alt=""
3.位图
基本使用
统计和查找
魔术指令 bitfield
data:image/s3,"s3://crabby-images/a58c1/a58c1cb028a480e34e80c1b0ea85eee9e8b0a152" alt=""
4.HyperLogLog
使用方法
pfadd 这个 pf 是什么意思?
pfmerge 适合什么场合用?
注意事项
HyperLogLog 实现原理
pf 的内存占用为什么是 12k?
data:image/s3,"s3://crabby-images/ed6ad/ed6ad9852b68722ce6f6c7bbc9d534ba19d27f7f" alt=""
5.布隆过滤器
布隆过滤器是什么?
Redis 中的布隆过滤器
布隆过滤器的基本使用
注意事项
布隆过滤器的原理
空间占用估计
实际元素超出时,误判率会怎样变化?
用不上 Redis4.0 怎么办?
布隆过滤器的其他应用
data:image/s3,"s3://crabby-images/7112f/7112f8deeef2064beb780cd8965a4501915ff2a7" alt=""
6.简单限流
如何使用 Redis 来实现简单限流策略?
data:image/s3,"s3://crabby-images/e007d/e007d73a9aa0bda2726180753ba55a539721aba8" alt=""
7.漏斗限流
Redis-Cell
一些思考
data:image/s3,"s3://crabby-images/ffd37/ffd375f8d88adf1d78acf985edcc2fc9eb860ec1" alt=""
8.GeoHash
用数据库来算附近的人
GeoHash 算法
Redis 的 Geo 指令基本使用
data:image/s3,"s3://crabby-images/03f83/03f834b159a7037e10ccff6c68e11ec84546b093" alt=""
9.Scan
scan 基础使用
字典的结构
scan 遍历顺序
字典扩容
对比扩容缩容前后的遍历顺序
渐进式 rehash
更多的 scan 指令
大 Key 扫描
data:image/s3,"s3://crabby-images/cae82/cae8229169ff48c9ce4365dc340ccc7713c62850" alt=""
PART3:Redis 的原理 1.线程 IO 模型
非阻塞 IO
事件轮询(多路复用)
指令队列
响应队列
定时任务
data:image/s3,"s3://crabby-images/5570d/5570d4d138f84549c1a9a7221774e55606da7fa9" alt=""
2.通信协议
RESP(Redis Serialization Protocol)
客户端->服务端
服务端->客户端
data:image/s3,"s3://crabby-images/68c92/68c92f6a0fb1df6382c3e3916ef3fe2221a3fb84" alt=""
3.持久化
快照原理
fork(多进程)
AOF 原理
AOF 重写
fsync
运维
Redis4.0 混合持久化
data:image/s3,"s3://crabby-images/18cbd/18cbdfba09d20954da7198071ed6dd5b3b717cf2" alt=""
4.管道
Redis 的消息交互
管道压力测试
深入理解管道本质
data:image/s3,"s3://crabby-images/70b3b/70b3b89a43db8bc7546cda4b9a73504c75a5371c" alt=""
5.事务
Redis 事务的基本使用
原子性
discard(丢弃)
优化
Watch
data:image/s3,"s3://crabby-images/5a914/5a914231e9f8f5e60b26121efbdfdd0540d416d6" alt=""
6.PubSub
消息多播
PubSub
模式订阅
消息结构
PubSub 缺点
data:image/s3,"s3://crabby-images/5c2b0/5c2b01e504e3fd0c922edb306cfbfd6fd2912470" alt=""
7.小对象压缩
32bit vs 64bit
小对象压缩存储(ziplist)
内存回收机制
内存分配算法
data:image/s3,"s3://crabby-images/d87fb/d87fb18422c2d19bb04f18802046dc933b83be77" alt=""
8.主从同步
CAP 原理
最终一致
主从同步
增量同步
快照同步
增加从节点
无盘复制
Wait 指令
data:image/s3,"s3://crabby-images/8753c/8753c45e43ff9a3c1fa31728e66a76719256f85e" alt=""
PART4:Redis 集群 1.Sentinel
消息丢失
Sentinel 基本使用
data:image/s3,"s3://crabby-images/566c1/566c1cbc5ba3d9048345ad4e52e04ab814b6f287" alt=""
2.Codis
Codis 分片原理
不同的 Codis 实例之间槽位关系如何同步?
扩容
自动均衡
Codis 的代价
Codis 的优点
MGET 指令的操作过程
架构变迁
Codis 的尴尬
Codis 的后台管理
data:image/s3,"s3://crabby-images/7a568/7a5681ee04679e379738cd628df3b7b174d573d3" alt=""
3.Cluster
槽位定位算法
跳转
迁移
容错
网络抖动
可能下线(PFAIL-Possibly Fail)与确定下线(Fail)
Cluster 基本使用
槽位迁移感知
集群变更感知
data:image/s3,"s3://crabby-images/2fd0d/2fd0db4aab33423238860557ef6e591c3861fad9" alt=""
PART5:Redis 拓展
1.Stream
消息 ID
消息内容
增删改查
独立消费
创建消费组
消费
Stream 消息太多怎么办?
消息如果忘记 ACK 会怎样?
PEL 如何避免消息丢失?
Stream 的高可用
分区 Partition
data:image/s3,"s3://crabby-images/08a9b/08a9be01cd7c2ba255fde976540b5bc745a98eb8" alt=""
Redis 每秒执行多少次指令?
Redis 连接了多少客户端?
Redisn 内存占用多大?
复制积压缓存区多大?
data:image/s3,"s3://crabby-images/28b9c/28b9c5673df20f332402d45a78634d6f39a199b8" alt=""
3.再谈分布式锁
Redlock 算法
Redlock 使用场景
data:image/s3,"s3://crabby-images/d17c6/d17c68002a9cd471a98cf32e32e6225747fcad3a" alt=""
4.过期策略
过期的 key 集合
定时扫描策略
从库的过期策略
data:image/s3,"s3://crabby-images/61923/619233a06a85ee6d32a59ae844869167051e78b6" alt=""
5.LRU
LRU 算法
近似 LRU 算法
data:image/s3,"s3://crabby-images/d0f4b/d0f4b58585179b7abfd1d3ad2cbfd8b4987282f2" alt=""
6.懒惰删除
Redis 为什么要懒惰删除(lazy free)?
flush
异步队列
AOF Sync 也很慢
更多异步删除点
data:image/s3,"s3://crabby-images/d5804/d5804e51d9774421fe61ecf74be0e35d2636397e" alt=""
7.优雅地使用 Jedis
重试
data:image/s3,"s3://crabby-images/7dc86/7dc86c9654968cb9ff590b6d977a8491dd903ad8" alt=""
8.保护 Redis
指令安全
端口安全
Lua 脚本安全
SSL 代理
data:image/s3,"s3://crabby-images/e738d/e738dce6f7705dcf1f6aa7cca922f5612946f33f" alt=""
9.Redis 安全通信
spiped 原理
spiped 使用入门
data:image/s3,"s3://crabby-images/7b562/7b5627a721c48a3f19a216067ff17cf132240738" alt=""
PART6:源码 1.探索字符串内部结构
embstr vs raw
扩容策略
data:image/s3,"s3://crabby-images/78774/7877472007c9fdde5817bbed964d15f76551f25f" alt=""
2.探索字典内部
dict 内部结构
渐进式 rehash
查找过程
hash 函数
hash 攻击
扩容条件
缩容条件
set 的结构
data:image/s3,"s3://crabby-images/809ae/809aeed10acdb28fdd7873f51ad817aeefd4ba22" alt=""
3.探索压缩列表内部
增加元素
级联更新
IntSet 小整数集合
data:image/s3,"s3://crabby-images/355f2/355f231948073e0d9ad0cdfb7863048d726eacaa" alt=""
4.探索快速列表内部
每个 ziplist 存多少元素?
压缩深度
data:image/s3,"s3://crabby-images/ae32b/ae32b2d6842b35a77147953541f3a30cdbc9642a" alt=""
5.探索跳跃列表内部结构
基本结构
查找过程
随机层数
插入过程
删除过程
更新过程
如果 score 值都一样呢?
元素排名是怎么算出来的?
data:image/s3,"s3://crabby-images/ce132/ce132ce1e2714021464fe256336fe47749a29645" alt=""
6.探索紧凑列表内部
级联更新
取代 ziplist
data:image/s3,"s3://crabby-images/73d9d/73d9daed3b41022c66d532b029a305c77ff7f652" alt=""
7.探索基数树内部
应用
结构
增删节点
data:image/s3,"s3://crabby-images/dd60c/dd60c3a6c3eec96486dd60b2f3cc5042e717e575" alt=""
Ps:由于篇幅限制,笔记无法全部为大家展示出来,就以截图主要内容的形式让大家参考啦,需要完整的朋友可以点击>>传送门<<获取
总结
最后,我想说的是,学习并非难事,而贵在坚持,尤其是在我们参与工作之后,要继续坚持学习就更不容易了。但对于程序员来说,学习是立业之根本,如若放弃学习,被市场淘汰是迟早的事情。所以,学习更多新的知识对于自己来说才是一种更大的投资。以上,到此结束。
评论