Redis面试相关内容了解下~(五) - Go语言中文社区

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


原文地址: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合成一条指令来用。

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

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

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

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

  

版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/luyaran/article/details/121530163
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2021-12-11 17:36:03
  • 阅读 ( 1496 )
  • 分类:面试题

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢