Redis 从入门到精通之Redis操作设置Key超时时间

本文涉及的产品
应用实时监控服务-应用监控,每月50GB免费额度
可观测监控 Prometheus 版,每月50GB免费额度
云原生网关 MSE Higress,422元/月
简介: Redis中可以使用`EXPIRE`命令为key设置超时时间,也可以使用`PEXPIRE`命令为key设置毫秒级别的超时时间。当key的超时时间到期后,key会被自动删除。

1.设置Key超时时间

Redis中可以使用EXPIRE命令为key设置超时时间,也可以使用PEXPIRE命令为key设置毫秒级别的超时时间。当key的超时时间到期后,key会被自动删除。

1. EXPIRE命令

EXPIRE命令用于为指定的key设置超时时间,单位为秒。以下是EXPIRE命令的操作示例:

  • jedis操作示例:

import redis.clients.jedis.Jedis;

public class JedisExample {
   
    public static void main(String[] args) {
   
        // 连接Redis服务器
        Jedis jedis = new Jedis("localhost", 6379);

        // 为key设置超时时间
        Long result = jedis.expire("foo", 60); // 60秒后过期
        System.out.println(result);

        // 关闭连接
        jedis.close();
    }
}
  • RedisTemplate操作示例:

import org.springframework.data.redis.core.RedisTemplate;

public class RedisTemplateExample {
   
    private RedisTemplate<String, String> redisTemplate;

    public RedisTemplateExample(RedisTemplate<String, String> redisTemplate) {
   
        this.redisTemplate = redisTemplate;
    }

    public void expire(String key, long timeout) {
   
        redisTemplate.expire(key, timeout, TimeUnit.SECONDS);
    }
}

2. PEXPIRE命令

PEXPIRE命令用于为指定的key设置毫秒级别的超时时间。以下是PEXPIRE命令的操作示例:

- jedis操作示例:

import redis.clients.jedis.Jedis;

public class JedisExample {
   
    public static void main(String[] args) {
   
        // 连接Redis服务器
        Jedis jedis = new Jedis("localhost", 6379);

        // 为key设置超时时间
        Long result = jedis.pexpire("foo", 60000); // 60秒后过期
        System.out.println(result);

        // 关闭连接
        jedis.close();
    }
}

RedisTemplate操作示例:

import org.springframework.data.redis.core.RedisTemplate;

public class RedisTemplateExample {
   
    private RedisTemplate<String, String> redisTemplate;

    public RedisTemplateExample(RedisTemplate<String, String> redisTemplate) {
   
        this.redisTemplate = redisTemplate;
    }

    public void pexpire(String key, long timeout) {
   
        redisTemplate.expire(key, timeout, TimeUnit.MILLISECONDS);
    }
}

3. 注意事项

在使用EXPIREPEXPIRE命令设置key的超时时间时需要注意以下几点:

  • 超时时间是相对于当前时间的时间差,因此要注意时区的问题。
  • 超时时间的设置是针对key的,每个key都需要单独设置超时时间。
  • 超时时间设置的最小单位是秒或毫秒,因此要根据实际需求选择合适的单位。
  • 如果对一个已经设置了超时时间的key再次设置超时时间,那么新的超时时间会覆盖旧的超时时间。
  • 如果想要取消key的超时时间,可以使用PERSIST命令或EXPIRE命令将超时时间设置为0。
  • EXPIREPEXPIRE命令的使用方法与其他Redis命令类似,可以通过jedis或RedisTemplate两种方式进行操作。
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
2月前
|
消息中间件 缓存 NoSQL
Redis 高并发竞争 key ,如何解决这个难点?
本文主要探讨 Redis 在高并发场景下的并发竞争 Key 问题,以及较为常用的两种解决方案(分布式锁+时间戳、利用消息队列)。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
Redis 高并发竞争 key ,如何解决这个难点?
|
2月前
|
存储 监控 NoSQL
Redis大Key问题如何排查?如何解决?
Redis大Key问题如何排查?如何解决?
86 0
Redis大Key问题如何排查?如何解决?
|
2月前
|
存储 NoSQL 算法
面试官:Redis 大 key 多 key,你要怎么拆分?
本文介绍了在Redis中处理大key和多key的几种策略,包括将大value拆分成多个key-value对、对包含大量元素的数据结构进行分桶处理、通过Hash结构减少key数量,以及如何合理拆分大Bitmap或布隆过滤器以提高效率和减少内存占用。这些方法有助于优化Redis性能,特别是在数据量庞大的场景下。
面试官:Redis 大 key 多 key,你要怎么拆分?
|
3月前
|
缓存 NoSQL Java
springboot的缓存和redis缓存,入门级别教程
本文介绍了Spring Boot中的缓存机制,包括使用默认的JVM缓存和集成Redis缓存,以及如何配置和使用缓存来提高应用程序性能。
133 1
springboot的缓存和redis缓存,入门级别教程
|
3月前
|
NoSQL Unix Redis
Redis 键(key)
10月更文挑战第15天
44 1
|
3月前
|
存储 消息中间件 NoSQL
Redis 入门 - C#.NET Core客户端库六种选择
Redis 入门 - C#.NET Core客户端库六种选择
77 8
|
3月前
|
NoSQL Java API
美团面试:Redis锁如何续期?Redis锁超时,任务没完怎么办?
在40岁老架构师尼恩的读者交流群中,近期有小伙伴在面试一线互联网企业时遇到了关于Redis分布式锁过期及自动续期的问题。尼恩对此进行了系统化的梳理,介绍了两种核心解决方案:一是通过增加版本号实现乐观锁,二是利用watch dog自动续期机制。后者通过后台线程定期检查锁的状态并在必要时延长锁的过期时间,确保锁不会因超时而意外释放。尼恩还分享了详细的代码实现和原理分析,帮助读者深入理解并掌握这些技术点,以便在面试中自信应对相关问题。更多技术细节和面试准备资料可在尼恩的技术文章和《尼恩Java面试宝典》中获取。
美团面试:Redis锁如何续期?Redis锁超时,任务没完怎么办?
|
3月前
|
缓存 监控 负载均衡
如何解决Redis热点Key问题?技术干货分享
【10月更文挑战第2天】在Redis的使用过程中,热点Key问题是一个常见的性能瓶颈。热点Key指的是那些被频繁访问的Key,它们可能导致Redis服务器的负载不均衡,进而影响整体性能。本文将深入探讨热点Key问题的成因、影响以及多种解决方案,帮助读者在实际工作中有效应对这一挑战。
137 3
|
3月前
|
NoSQL Redis
redis 的 key 过期策略是怎么实现的(经典面试题)超级通俗易懂的解释!
本文解释了Redis实现key过期策略的方式,包括定期删除和惰性删除两种机制,并提到了Redis的内存淘汰策略作为补充,以确保过期的key能够被及时删除。
64 1
|
15天前
|
存储 缓存 NoSQL
解决Redis缓存数据类型丢失问题
解决Redis缓存数据类型丢失问题
158 85