2019.6.30 redis知识点

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

redis是单线程的,

1.为什么快?

纯内存操作

单线程,减少了上下文切换

非阻塞I/O多路复用

2.数据类型?

string

hash:value=>结构化对象|模拟session效果

list:模拟简单的消息队列、排队|redis可用于分页

set:全局去重

sored set:多了一个权重参数sare|排行榜、取topn

3.redis的过期策略以及内存淘汰机制

定期删除+惰性删除

4.redis和数据库双写一致性问题(只能降低概率,不能避免)

更新策略:先更新数据库,再更新缓存

删除缓存失效:补偿机制

5.缓存穿透和缓存雪崩

缓存穿透:黑色故意去请求缓存中不存在的数据,导致所有请求都怼到数据库上,从而链接失常

解决:互斥锁、异步更新策略、提供一个能迅速判断请求是否有效的拦截机制

缓存雪崩:

解决:给缓存一个随机失效时间、互斥锁、双缓存

6.解决redis的并发竞争key问题:

不要求顺序:分布式锁,大家去抢锁

要求顺序:保存一个时间戳

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值