简单聊一聊redis过期时间的问题

 更新时间:2023年04月14日 11:51:11   作者:凌晨四点的打铁声  
在使用redis的过期时间时不由想到设置了过期时间,下面这篇文章主要给大家介绍了关于redis过期时间问题的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下

1.多次修改一个redis的String过期键,如何保证他仍然能保留第一次设置时的删除时间

对于修改String,redis有:set、setex、append、incr、decr等,其中,使用set、setex来修改原来存在的String,会重置原来设置过的过期时间,严格来说set、setex不是“修改”,而是覆盖,所以原来设置过的key-value,再次set/setex这个key就会覆盖掉原来的。使用try redis(网址:https://try.redis.io/)测试结果如下:

如果使用append、incr、decr等命令来修改,并不会重置原来的过期时间:

所以,对于 string 结构,只要进行 set /setex命令,就会重置过期时间,而set命令会直接把过期时间变为永不过期。
比如我在7:00设置了一个 {key1:value} ,过期时间为30分钟,在7:00-7:30期间多次set/setex这个 key 的 value,这个 key1 的过期时间都会重置,最终不会在7:30过期。如何保证每次设置这个过期键后不刷新过期时间,稳定在7:30过期?

方法一:

使用 定时器,第一次 set 的时候就创建一个定时器,到期就把这个 key 删除。这种方法在数据量大时会比较占用cpu资源,不推荐。

方法二:

每次setex key的 value 之前,先返回此时key的剩余过期时间,在setex时把这个剩余的过期时间赋给这个 key 作为新的过期时间,就可以解决。

以Spring项目为例,利用 redisTemplate.getExpire(String key) 方法返回的剩余过期时间戳(毫秒级别)可以解决,本质上是给 redis 发送 PTTL 命令,以返回毫秒为单位的key的剩余过期时间。

代码例子:

让 key1 每次修改 都保持第一次设置时的过期时间

//获取key1的剩余时间的时间戳
Long expire = redisTemplate.getExpire("key1");
//最后一个参数可以选秒、毫秒(TimeUnit.MILLISECONDS),Redis最多只能返回毫秒级别的key的剩余过期时间
redisTemplate.opsForValue().set(key, value, expire, TimeUnit.SECONDS);

2.修改hash、set、Zset、list的值,会使过期时间重置吗?

String类型的K-V 的有效期会随着的 value 值的修改,重新计时:

如存在一个 K-V ,过期时间为30秒, 如果把 value 值修改,则过期时间就会重置为30秒,而不是在原来设定的时间减去已经流失的时间。

除了string数据结构,对其他数据结构进行修改,不会重置过期时间

比如hash、set、Zset、list等:

以hash为例子:

hash 的有效期不会随着 hash 字段值的修改重新计时。
如果需要重新计时,则需要在修改字段值的时候,重新指定有效期。

总结

到此这篇关于redis过期时间问题的文章就介绍到这了,更多相关redis过期时间问题内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 浅析Redis Sentinel 与 Redis Cluster

    浅析Redis Sentinel 与 Redis Cluster

    本文主要介绍Redis Sentinel 及 Redis Cluster的区别及用法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-06-06
  • Redis实现分布式锁的实例讲解

    Redis实现分布式锁的实例讲解

    在本篇文章里小编给大家整理了一篇关于Redis实现分布式锁的实例讲解内容,有兴趣的朋友们可以学习参考下。
    2021-12-12
  • 利用Redis实现SQL伸缩的方法

    利用Redis实现SQL伸缩的方法

    本文主要介绍了如何通过锁和时间序列等方面来提升传统数据库的性能等方法,利用Redis实现SQL伸缩,供有需要的朋友们参考。
    2015-09-09
  • redis与memcached的区别_动力节点Java学院整理

    redis与memcached的区别_动力节点Java学院整理

    Memcached是以LiveJurnal旗下Danga Interactive公司的Bard Fitzpatric为首开发的高性能分布式内存缓存服务器。那么redis与memcached有什么区别呢?下面小编给大家介绍下redis与memcached的区别,感兴趣的朋友参考下吧
    2017-08-08
  • 详解Redis基本命令与使用场景

    详解Redis基本命令与使用场景

    REmote DIctionary Server(Redis)是一个由Salvatore Sanfilippo写的key-value 存储系统,是跨平台的非关系型数据库,是一个开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于内存、分布式、可选持久性的键值对(Key-Value)存储数据库,并提供多种语言的 API。
    2021-06-06
  • 一文带你了解Redis的三种集群模式

    一文带你了解Redis的三种集群模式

    Redis 的常用的集群方式主要有以下三种,分别是主从复制模式、哨兵模式、Redis-Cluster集群模式,那么下面我们就分别了解一下这三种集群模式的优点与缺点
    2023-06-06
  • 关于redis的延迟双删策略总结

    关于redis的延迟双删策略总结

    这篇文章主要介绍了关于redis的延迟双删策略总结,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • 如何使用gradle将java项目推送至maven中央仓库

    如何使用gradle将java项目推送至maven中央仓库

    本文主要介绍了使用gradle将java项目推送至maven中央仓库,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • CentOS8.4安装Redis6.2.6的详细过程

    CentOS8.4安装Redis6.2.6的详细过程

    本文给大家介绍CentOS8.4安装Redis6.2.6的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2021-11-11
  • Redis全局ID生成器的实现

    Redis全局ID生成器的实现

    全局ID生成器,是一种在分布式系统下用来生成全局唯一ID的工具,本文主要介绍了Redis全局ID生成器的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06

最新评论