1、Redis适用场景?
- 会话存储(session cache):用Redis缓存会话比其它存储(memcache)的优势在于Redis提供持久化操作。
- 全页缓存(FPC)。
- 队列。
- 排行榜/计数器。
- 发布/订阅:建立聊天系统。
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合成一条指令来用。
至此,本次分享就结束了,后期会慢慢补充。