Redis面试相关内容了解下~(五)

161 篇文章 12 订阅

原文地址:Redis面试相关内容了解下~(五)

1、Redis适用场景?

  1. 会话存储(session cache):用Redis缓存会话比其它存储(memcache)的优势在于Redis提供持久化操作。

  2. 全页缓存(FPC)。

  3. 队列。

  4. 排行榜/计数器。

  5. 发布/订阅:建立聊天系统。

2、如何在1亿个key中获取到其中10万以已知前缀开头的key?

可使用keys指令扫出指定模式的key列表,如Redis正在线上提供服务,则使用scan指令,但会产生重复率,可在客户端做一次去重,整体花费的时间相对于keys指令要长得多,但不会影响线上运行效率和性能。

3、大量key同时过期怎么办?

如大量key过期时间设置的过于集中,则会出现上述情况,Redis会出现卡顿,解决方案很简单,设置时间加上一个随机值,使得过期时间分散开就行了。

4、Redis异步队列怎么用?

使用list数据结构作为队列,rpush产生消息,lpop消费消息,当lpop没有消息的时候,要适当的sleep一会儿之后再重试。

如不想用sleep,还可使用blpop指令,它会阻塞到队列中有新消息。

5、Redis能不能实现一次生产多次消费?

使用publish/subscribe主题订阅模式,可实现读写比为N:1的消息队列。

publish/subscribe主题订阅模式在消费者下线时,生产者生产的消息会丢失,需使用专业的消息队列服务(如RabbitMQ)。

6、Redis如何实现延时队列?

使用sorted set数据类型,以时间戳作为score,消息内容作为key调用zadd生产消息,消费者使用zrangebyscore指令轮询获取N秒之前的数据进行处理。

7、Redis分布式锁?

先使用setnx竞争锁,到手之后使用expire给锁加一个过期时间防止锁忘记释放,顺带提一句,set指令可通过参数同时将setnx和expire合成一条指令来用。

至此,本次分享就结束了,后期会慢慢补充。

以上仅为个人观点,不一定准确,能帮到各位那是最好的。

好啦,到这里本文就结束了,喜欢的话就来个三连击吧。

扫码关注公众号,获取更多优质内容。

  

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

luyaran

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值