redis是单线程的,
1.为什么快?
纯内存操作
单线程,减少了上下文切换
非阻塞I/O多路复用
2.数据类型?
string
hash:value=>结构化对象|模拟session效果
list:模拟简单的消息队列、排队|redis可用于分页
set:全局去重
sored set:多了一个权重参数sare|排行榜、取topn
3.redis的过期策略以及内存淘汰机制
定期删除+惰性删除
4.redis和数据库双写一致性问题(只能降低概率,不能避免)
更新策略:先更新数据库,再更新缓存
删除缓存失效:补偿机制
5.缓存穿透和缓存雪崩
缓存穿透:黑色故意去请求缓存中不存在的数据,导致所有请求都怼到数据库上,从而链接失常
解决:互斥锁、异步更新策略、提供一个能迅速判断请求是否有效的拦截机制
缓存雪崩:
解决:给缓存一个随机失效时间、互斥锁、双缓存
6.解决redis的并发竞争key问题:
不要求顺序:分布式锁,大家去抢锁
要求顺序:保存一个时间戳

本文深入探讨Redis作为单线程数据库的高效运行原理,包括纯内存操作、非阻塞I/O多路复用等优势,同时解析其数据类型如String、Hash、List、Set和Sorted Set的使用场景。此外,文章还讨论了Redis的过期策略、内存淘汰机制,以及与数据库双写一致性的解决方案。针对缓存穿透和缓存雪崩现象,提出了多种预防措施。
7791

被折叠的 条评论
为什么被折叠?



