草庐IT

Redis中的ttl命令用法解析

一、语法格式:ttlkey二、作用:查看键还有多少秒过期。三、返回值代表的意义:-1表示永不过期,-2表示已经过期。 

node.js - TTL 过期时的事件

当特定键的TTL过期时,Redis会发出任何类型的事件吗?我希望在任何给定时间点为我的应用程序添加Redis中的键数。我在生成key时有一个递增计数器,同样我希望在key过期(TTL过期)时有一个递减计数器。我知道我可以通过执行“KEYS”来实现这一点,但我想知道Redis是否会生成某种事件,当key过期时我可以捕获这些事件。我将使用NodeJS来捕获事件。谢谢,拉古。 最佳答案 不要在生产中使用KEYS-它可能是一个长时间运行、消耗RAM、拒绝服务的操作。是的,从v2.8.0开始,Redis确实有您要找的东西。阅读RedisKey

node.js - TTL 过期时的事件

当特定键的TTL过期时,Redis会发出任何类型的事件吗?我希望在任何给定时间点为我的应用程序添加Redis中的键数。我在生成key时有一个递增计数器,同样我希望在key过期(TTL过期)时有一个递减计数器。我知道我可以通过执行“KEYS”来实现这一点,但我想知道Redis是否会生成某种事件,当key过期时我可以捕获这些事件。我将使用NodeJS来捕获事件。谢谢,拉古。 最佳答案 不要在生产中使用KEYS-它可能是一个长时间运行、消耗RAM、拒绝服务的操作。是的,从v2.8.0开始,Redis确实有您要找的东西。阅读RedisKey

Redis 数据库 TTL

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

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已过期,您将必须检查