济南最好的网站制作公司,自己做app难吗,福建建设工程报建网站,兰州城乡建设局网站一般情况下#xff0c;我们设置保存的缓存数据的时候都会设置一个过期时间。Redis 中有个设置时间过期的功能#xff0c;即对存储在 Redis 数据库中的值可以设置一个过期时间。作为一个缓存数据库#xff0c;这是非常实用的。如我们一般项目中的 token 或者一些登录信息我们设置保存的缓存数据的时候都会设置一个过期时间。Redis 中有个设置时间过期的功能即对存储在 Redis 数据库中的值可以设置一个过期时间。作为一个缓存数据库这是非常实用的。如我们一般项目中的 token 或者一些登录信息尤其是短信验证码都是有时间限制的按照传统的数据库处理方式一般都是自己判断过期这样无疑会严重影响项目性能。我们 set key 的时候都可以给一个 expire time就是过期时间通过过期时间我们可以指定这个 key 可以存活的时间。如果假设你设置了一批 key 只能存活 1 个小时那么接下来 1 小时后Redis 是怎么对这批 key 进行删除的定期删除惰性删除。通过名字大概就能猜出这两个删除方式的意思了。定期删除Redis 默认是每隔 100ms 就随机抽取一些设置了过期时间的 key检查其是否过期如果过期就删除。注意这里是随机抽取的。为什么要随机呢你想一想假如 Redis 存了几十万个 key 每隔 100ms 就遍历所有的设置过期时间的 key 的话就会给 CPU 带来很大的负载惰性删除定期删除可能会导致很多过期 key 到了时间并没有被删除掉。所以就有了惰性删除。假如你的过期 key靠定期删除没有被删除掉还停留在内存里除非你的系统去查一下那个 key才会被 Redis 给删除掉。这就是所谓的惰性删除也是够懒的哈但是仅仅通过设置过期时间还是有问题的。我们想一下如果定期删除漏掉了很多过期 key然后你也没及时去查也就没走惰性删除此