正如Java虚拟机,Redis也提供了自动GC(垃圾回收)的功能,来保证Java程序Java程序使用过且不再使用的Java对象及时地从内存中释放掉,从而保证内存空间可用。
在谈论Redis内存回收之前,首先要讨论的是键值对的超时命令,因为大部分情况下,我们都想要回收那些超时的键值对,而不是那些非超时的键值对。Redis的超时命令如下所示:
- persist key:持久化key,取消超时时间,也就是移除key的超时时间。
- ttl key:查看key的超时时间。
- expire key seconds:设置超时时间戳,以秒为单位。
- expireat key timestamp:设置超时时间点,用uninx时间戳确定。
- pptl key milliseconds:查看key的超时时间戳。用毫秒计算。
- perpire key:设置键值超时的时间。
- pexpireat key stamptimes:设置超时时间点。
还有一个问题需要讨论:如果key超时了,Redis会回收key的存储空间吗?
答案是不会,Redis的key超时不会被其自动回收,它只会标识哪些键值对超时了。这样做的一个好处在于,如果一个很大的键值对超时了,比如一个列表或者哈希结构,存在着数以万个的元素,要对其回收需要很长的时间。如果采用超时回收,则可能产生停顿。坏处也很明显,这些超时的键值对会浪费比较多的空间。
Redis提供两种方式回收这些超时键值对:
- 定时回收:再确定的某个时间触发一段代码,回收超时的键值对。
- 惰性回收:当一个超时的键,被再次用get命令访问时,将触发Redis将其从内存中清空。
本文探讨了Redis的内存管理机制,包括自动GC功能及其与Java虚拟机的区别,详细介绍了Redis键值对的超时命令及其实现原理。文章还分析了超时键值对的回收策略,包括定时回收和惰性回收,以及它们对内存效率的影响。
1688

被折叠的 条评论
为什么被折叠?



