问题1:刚刚向redis中插入的数据怎么没了?
问题2:我插入redis的数据应该过期了,为什么还占用内存?
如果有以上问题说明你还不了解Redis的内存淘汰机制
问题1的解决:设置redis中key的过期时间
redis> SET cache_page "www.google.com"
OK
redis> EXPIRE cache_page 30 # 设置过期时间为 30 秒
(integer) 1
我们set key的时候,都可以给一个expire time,就是过期时间,指定这个key比如说只能存活1个小时?10分钟?这个很有用,我们自己可以指定缓存到期就失效。
如果假设你设置一个一批key只能存活1个小时,那么接下来1小时后,redis是怎么对这批key进行删除的?
1.redis的过期策略
redis的过期策略:定期删除+惰性删除
- 定期删除:redis默认是每隔100ms就随机抽取一些设置了过期时间的key,检查其是否过期,如果过期就删除。
- 惰性删除:在你获取某个key的时候,redis会检查一下 ,这个key如果设置了过期时间那么是否过期了?如果过期了此时就会删除,不会给你返回任何东西
可是有了定期删除和惰性删除就可以保证过期的key真的被删掉吗?
当然不能,问题2就是一个明显的例子