在redis中,我要首先获取然后设置一个值的哈希值。我认为我可以使用流水线通过缩小往返行程来加快整个操作,如下所示:

my_pipeline = redis.Redis(connection_pool=POOL).pipeline()
my_pipeline.hget("my_hash","my_time")
my_pipeline.hset("my_hash","my_time",latest_time)
result = my_pipeline.execute()
old_value_of_my_time = result[0]

本质上,我尝试检索my_time的原始值以供以后使用,然后设置一个新值。

所以问题是:在同一管道中对相同值执行hgethset正确吗?我从this SO post(以及管道的常识)了解到,命令的顺序保留在管道中。从表面上看,我的方法应该是正确的。

但是我可能会遗漏一些东西,所以专家可以审查这种方法吗?

注意:我在示例代码中使用了python语法。而且,如果我不使用哈希,则只需使用getset进行此操作。但是请注意,在这种情况下,我必须使用哈希-出于此问题范围之外的原因。

最佳答案

是的,您可以在管道中执行HGETHSET。但是,它的行为与GETSET略有不同。 GETSET是原子操作,但是管道中HGETHSET的组合是而不是原子。

Redis保证它在HGET命令之前运行HSET命令。但是,Redis 不会原子地运行这两个命令。因此,当它运行HSET命令时,其他客户端可能已经修改了HASH。在这种情况下,您不会获得旧值,而是获得一些旧值。

为了实现类似于GETSET的功能,您已在事务中运行HGETHSET,或将这两个命令包装在Lua脚本中。

10-06 10:57