Redis的Key过期策略和内存回收机制(附加面试常问问题及代码举例)
Redis的key过期策略和内存回收机制是Redis高级特性的重要组成部分。
问题1:Redis的key过期策略有哪些?
Redis使用两种策略来处理过期的key:惰性和定时。
- 惰性过期:当get key时,检查是否过期,如果过期则删除。
- 定时过期:每隔一段时间,随机抽查一些key,检查并删除过期的key。
问题2:Redis如何实现内存回收?
Redis使用内存回收策略来管理内存的使用。
- 当内存达到maxmemory时,会触发内存回收。
- 回收策略包括:noeviction(不回收),allkeys-lru(按最少最近使用),volatile-lru(只对设置了过期时间的key按最少最近使用),allkeys-random(随机删除key),volatile-random(随机删除设置了过期时间的key),volatile-ttl(删除即将过期的key)。
问题3:如何在Redis中设置内存回收策略?
可以通过配置文件或者CONFIG SET
命令来设置内存回收策略。
# 设置内存回收策略为allkeys-lru
CONFIG SET maxmemory-policy allkeys-lru
问题4:如何在Redis中设置key的过期时间?
可以使用EXPIRE
命令设置key的过期时间(秒),或者PEXPIRE
设置过期时间(毫秒)。
# 设置key为"mykey"的过期时间为300秒
EXPIRE mykey 300
问题5:Redis的内存用尽时如何处理写请求?
当Redis内存达到maxmemory限制时,根据设置的内存回收策略,如果策略是noeviction,则不接受新的写入命令;如果是其他策略,则会根据策略来删除一些key来为新的数据腾出空间。
问题6:Redis的内存用尽时如何处理读请求?
即使内存达到限制,Redis也会尝试处理读请求,如果key已经过期,会在返回之前检查并删除过期的key。
问题7:Redis的内存用尽时如何处理删除请求?
当需要删除key来释放内存时,Redis会从数据集中随机抽查一些key,并检查它们是否过期,如果是,则删除。
问题8:Redis的内存用尽时如何处理数据迁移?
Redis可以配置数据持久化,当内存数据超过最大内存时,可以将热数据保存到磁盘上,并在需要时从磁盘中加载到内存中。
问题9:Redis的内存用尽时如何监控?
可以使用INFO memory
命令来获取Redis的内存使用情况,包括内存占用、内存碎片率等信息。
# 查看Redis内存使用信息
INFO memory
以上回答提供了Redis key过期策略、内存回收策略的概述,并展示了如何在Redis中设置和获取相关配置,以及如何处理内存达到上限的情况。
评论已关闭