Redis设置过期时间

在使用redis作为缓存存储值的时候,一般都是需要设置值的过期时间,否则日积月累的垃圾数据就会占用大量的内存空间;

设置过期时间可以分开设置也可以一条语句设置

分开设置

先设置值再设置过期时间,这种方式极端情况下会出现问题,毕竟是非原子操作。

	// 两条命令分别设置值和过期时间
	// 时间单位:秒
	redis.expire("key",6);
	// 时间单位:毫秒
	//redis.pexpire("key",6000L);

合并设置

一条命令同时设置值和过期时间,推荐使用此方式。

	// 一条语句设置值和过期时间
    // 时间单位:秒
	redis.setex("key",6,"value");
    // 时间单位:毫秒
	//redis.psetex("key",6000L,"value");

一般主要包括2种处理过期方式,其中expire都是以秒为单位,pexpire都是以毫秒为单位的。

第一种

设置值的有效时间。

    expire (key seconds)        // 为给定 key 设置过期时间,以秒计。
    pexpire (key milliseconds)  // 设置 key 的过期时间以毫秒计。
    setex(String key, long seconds, String value) // 建议使用原子操作设置过期时间,而不是先设置值再设置过期时间

第二种

设置值的到期时间,根据时间的时间戳设置,例如:2021年6月1号上午10点10分10秒到期,就填此时刻的时间戳

// 设置 key 过期时间的时间戳(unix timestamp) 单位:秒时间戳,
// 例如:2021年6月1号上午10点10分10秒到期 timestamp=1622513410
expireat (key timestamp)

// 设置 key 过期时间的时间戳(unix timestamp) 单位:毫秒时间戳
// 例如:2021年6月1号上午10点10分10秒到期 timestamp=1622513410000
pexpireat (key milliseconds-timestamp)

注:更新值会清除过期时间,如果用DEL, SET, GETSET会将key对应存储的值替换成新的,命令也会清除掉超时时间;如果list结构中添加一个数据或者改变hset数据的一个字段是不会清除超时时间的;如果想要通过set去覆盖值那就必须重新设置expire。

你可能感兴趣的:(redis,java,redis,redis过期时间)