草庐IT

Redis 数据库 TTL

有没有办法创建一个Redis数据库,其中的键必须在特定时间后过期?我知道我可以使用EXPIRE命令使单个key过期,但由于无论如何我都会在特定时间后使每个key过期,因此最好在Redis配置文件中指定此行为。 最佳答案 不,Redis(直到并包括v3.2)不提供自动设置新创建键的TTL的方法。您必须为您创建的每个key明确设置它。 关于Redis数据库TTL,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.c

redis - 如何在 ServiceStack.Redis 中设置 TTL 以列出值?

我在ServiceStack.Redis中有一个列表,我想设置一个TimeSpan使其过期。也就是说,如何在ServiceStack.Redis中调用下面的redis命令EXPIREListIdttl我想要的方法是:client.Lists(listId,timespan);我的问题有解决方案吗? 最佳答案 通过IRedisClient和IRedisNativeClient上的新Custom和RawCommandAPI,您现在可以使用RedisClient发送您自己的自定义命令,这些命令可以调用adhocRedis命令:public

redis - 如何在 ServiceStack.Redis 中设置 TTL 以列出值?

我在ServiceStack.Redis中有一个列表,我想设置一个TimeSpan使其过期。也就是说,如何在ServiceStack.Redis中调用下面的redis命令EXPIREListIdttl我想要的方法是:client.Lists(listId,timespan);我的问题有解决方案吗? 最佳答案 通过IRedisClient和IRedisNativeClient上的新Custom和RawCommandAPI,您现在可以使用RedisClient发送您自己的自定义命令,这些命令可以调用adhocRedis命令:public

java - Spring Data Redis 在 TTL 到期后不清理辅助地理空间索引

使用以下模型:@RedisHash("positions")publicclassPosition{@IdprivateStringid;@GeoIndexedprivatePointcoordinates;@TimeToLive(unit=TimeUnit.MINUTES)protectedintttl;//...}我注意到一些数据在TimeToLive过期后仍然存在。注意过期事件前后keys*命令的区别:之前127.0.0.1:6379>keys*1)"positions:336514e6-3e52-487a-a88b-98b110ec1c28"2)"positions:coord

java - Spring Data Redis 在 TTL 到期后不清理辅助地理空间索引

使用以下模型:@RedisHash("positions")publicclassPosition{@IdprivateStringid;@GeoIndexedprivatePointcoordinates;@TimeToLive(unit=TimeUnit.MINUTES)protectedintttl;//...}我注意到一些数据在TimeToLive过期后仍然存在。注意过期事件前后keys*命令的区别:之前127.0.0.1:6379>keys*1)"positions:336514e6-3e52-487a-a88b-98b110ec1c28"2)"positions:coord

redis - 当列表在 redis 中变空时,列表的 ttl 消失

在Redis中,我使用Lpush将一个元素插入到列表中并设置了一个过期时间。在程序执行过程中,更多的元素将被插入和弹出列表。但是当列表变空时,列表的结算到期时间将丢失。有没有办法保留旧列表,即使它是空的?作为黑客,我在Redis中放置了一个虚拟对象以保持它是ttl,但这是一个糟糕的解决方案。请帮忙。 最佳答案 不,正在删除空列表。请参阅它说的文档:theresultwillbeanemptylist(whichcauseskeytoberemoved)作为替代方案,您可以使用单独的简单key来保持过期。如果key已过期,您将必须检查

redis - 当列表在 redis 中变空时,列表的 ttl 消失

在Redis中,我使用Lpush将一个元素插入到列表中并设置了一个过期时间。在程序执行过程中,更多的元素将被插入和弹出列表。但是当列表变空时,列表的结算到期时间将丢失。有没有办法保留旧列表,即使它是空的?作为黑客,我在Redis中放置了一个虚拟对象以保持它是ttl,但这是一个糟糕的解决方案。请帮忙。 最佳答案 不,正在删除空列表。请参阅它说的文档:theresultwillbeanemptylist(whichcauseskeytoberemoved)作为替代方案,您可以使用单独的简单key来保持过期。如果key已过期,您将必须检查

尽管设置了 TTL,但 Redis 缓存未被清除

我想让存储在redis缓存中的数据在给定时间后自动从缓存中清除,而不需要调用它的delete方法。在此POC中,我将TTL设置为60秒。我已经尝试使用APIsetDefaultExpiration、setExpires在缓存管理器中设置它,并使用API过期在RedisTemplate中设置它。到目前为止,没有一种解决方案对我有用。@ConfigurationpublicclassRedisServerConfigextendsCachingConfigurerSupport{@BeanpublicRedisTemplateredisTemplate(){RedisTemplatered

尽管设置了 TTL,但 Redis 缓存未被清除

我想让存储在redis缓存中的数据在给定时间后自动从缓存中清除,而不需要调用它的delete方法。在此POC中,我将TTL设置为60秒。我已经尝试使用APIsetDefaultExpiration、setExpires在缓存管理器中设置它,并使用API过期在RedisTemplate中设置它。到目前为止,没有一种解决方案对我有用。@ConfigurationpublicclassRedisServerConfigextendsCachingConfigurerSupport{@BeanpublicRedisTemplateredisTemplate(){RedisTemplatered

redis - GET 和 TTL 的 SETEX 等价物

SETEX是一个有用的Redis命令,通过它可以在单个原子操作中设置键的value和expiry。是否有一个等效的操作可以使一个人以原子方式检索key的value和ttl?我知道我也可以在管道中做到这一点,但我想问的是是否存在像SETEX这样优雅的东西。如果重要的话,我使用的是Redis2.8.4。 最佳答案 据我所知,没有这样的命令。但是,您可以将GET和TTL包装到Lua脚本中,以在单个原子调用中同时获取值和ttl。此外,您不能通过流水线实现这一目标。因为Redis不保证管道中的命令以原子方式运行。