Redis基本问题

一、Redis是什么?

redis是使用C语言编写的一个高速缓存数据,它以key-value形式存储数据,而且它支持的数据类型非常丰富。

二、Redis都有哪些使用场景?

1.热点数据的缓存
2.计时器
3.排行榜。
4.实现分布式锁
5.使用session的共享

三、Redis支持的数据类型有哪些?

1.String 2. Hash 3.List 4.Set 5.ZSet

四、Redis为什么是单线程的?

因为Redis是基于内存的操作,CPU不是Redis的瓶颈,Redis的瓶颈最有可能是机器内存的大小或者网络带宽。既然单线程容易实现,而且CPU不会成为瓶颈,那就顺理成章地采用单线程的方案了。

五、Redis真的是单线程的吗?

并不是真的单线程,比如:RDB—Bgsave时,创建一个子线程

六、Redis持久化有几种方式?

RDB:
AOF:

七、什么是缓存穿透?怎么解决?

1.查询的数据在数据库中不存在,缓存中也不存在,这时有可能有人恶意访问这种数据。这些请求都会访问数据库,从而出现数据库压力过大。

情景: 比如id不合法—​ 确实数据库中不存在。
解决:

  1. 在controller加校验
    2. 我们可以在缓存中存入一个空对象,但是对象的过期时间不要太长,一般不会超过5分钟。
    3. 可以使用布隆过滤器

八、怎么保证缓存和数据库数据的一致性?

1.设置合理的过期时间
2.当执行增删改时需要删除缓存数据

九、Redis,什么是缓存雪崩?怎么解决?

缓存雪崩:就是在某一时刻出现大量数据过期,而这时就有大量的请求访问该数据,这种现象叫做缓存雪崩。

什么情况下会出现大量数据过期:

  1. 项目刚刚上线
  2. redis服务器宕机
  3. 缓存数据真实过期

解决方案:

  1. 上线前预热数据。
  2. 集群
  3. 设置过期时间时要分散设置。

十、Redis怎么实现分布式锁?

使用redis中的setnx命令–占锁,当业务代码执行完毕后是否锁资源,而释放锁的命令是del。

十一、 redis在实现分布式锁式有什么缺陷

超时问题: 业务代码执行时间超过锁时间。使用:watchDog机制。 我们使用第三方:redisson

十二、Redis 淘汰策略有哪些

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值