Redis数据类型有哪些?雪崩、击穿、穿透?

数据类型

​ 1. String:用于缓存、计数器、分布式锁等场景。

​ 2. Hash:用于存储对象,例如用户信息、商品信息等。

​ 3. List:可以进行队列和栈的操作常用于消息队列、任务队列等场景。

​ 4. Set:可以进行集合运算,例如并集、交集、差集等操作常用于标签、好友列表等场景

​ 5. ZSet:可以按照分数排序,也可以进行范围查询。常用于排行榜、计分系统等场景。

缓存问题

​ 1. 缓存穿透:当一个查询的数据在缓存中不存在,但在数据库中也不存在时,这个查询会穿透到数据库,导致数据库负载过高 解决方法使用布隆过滤器,将不存在于数据库的数据进行过滤;对于查询结果为空的 key,设置空值缓存,有效时间设置短一些

​ 2. 缓存击穿:当一个热点数据过期时,大量的请求会同时访问数据库,导致数据库负载过高。解决方法有:设置热点数据永不过期,定期更新缓存

​ 3. 缓存雪崩:当大量的缓存数据同时过期时,大量的请求会同时访问数据库,导致数据库负载过高 解决方法:给缓存的key设置随机过期时间,防止大量的缓存数据同时过期

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值