在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
的原始值以供以后使用,然后设置一个新值。所以问题是:在同一管道中对相同值执行
hget
和hset
正确吗?我从this SO post(以及管道的常识)了解到,命令的顺序保留在管道中。从表面上看,我的方法应该是正确的。但是我可能会遗漏一些东西,所以专家可以审查这种方法吗?
注意:我在示例代码中使用了python语法。而且,如果我不使用哈希,则只需使用
getset
进行此操作。但是请注意,在这种情况下,我必须使用哈希-出于此问题范围之外的原因。 最佳答案
是的,您可以在管道中执行HGET
和HSET
。但是,它的行为与GETSET
略有不同。 GETSET
是原子操作,但是管道中HGET
和HSET
的组合是而不是原子。
Redis保证它在HGET
命令之前运行HSET
命令。但是,Redis 不会原子地运行这两个命令。因此,当它运行HSET
命令时,其他客户端可能已经修改了HASH
。在这种情况下,您不会获得旧值,而是获得一些旧值。
为了实现类似于GETSET
的功能,您已在事务中运行HGET
和HSET
,或将这两个命令包装在Lua
脚本中。